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(54) High density two dimensional symbol set 

(57) A nonvolatile electro-optical read-only memory 
includes a substrate on which is printed (or otherwise 
inscribed) a complex symbol or "label" with a high den- 
sity two-dimensional symbology, a variable number of 
component symbols or "codewords" per row. and a var- 
iable number of rows. Codeworcte in alternating rows 
are selected from mutually exclusive subsets of a mark 
pattern such as a (17.4) mark pattern. The subsets are 
defined in terms of particular values of a discriminator 
function, which is illustrated as being a function of the 
widths of bars and spaces in a given codeword. In the 
illustrated embodiment, each subset includes 929 avail- 
able codewords; that, plus a two-step method of decod- 
ing scanned data, permitting significant flexibility in 
defining mappings of human-readable symbol sets into 
codewords. The memory may be used In conjunction 
with a scanner and a suitable control system in a 
number of applications, e.g., robotic operations or auto- 
mated microfilm searching. 
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Description 

1 . Background of the Invention 

5 The present invention relates to a method of reading and decoding a machine readable symbol, the symbol includ- 
ing a plurality of adjacent groups of codewords, each group comprising a plurality of individual codewords having a 
detectable mark/space pattern. It further relates to apparatus for reading and decoding such symbols. Typically, the 
symbol is printed or othenwise inscribed on a substrate, thereby defining a non-volatile electro-optical read-only mem- 
ory. The symbol or "label" typically has a high density two<limensional symbology, a variable number of component 

10 symbols or "codewords'* per line, and a variable number of lines. 

1.1 Bar Code Symboiogy 

A bar code Is typically a linear anay of elements that are either printed directly on an object or on labels that are 
15 affixed to the object. As shown in Figures 1 and 2, bar code elements typically comprise bars and spaces, with bars 
varying widths representing strings of binary ones and spaces of varying widths representing strings of binary zeros. 
Many bar cxxjes are optically detectable and are read by devices such as scanning laser beams or handheld wands. 
Other bar codes are implemented in magnetic media. The readers and scanning systems electro-optically decode the 
symbol to multiple alphanumerical characters that are intended to be descriptive of the article or some characteristic 
20 thereof. Such characters are typically represented in digital form as an input to a data processing system for applica- 
tions in point-of-sale processing, inventory control, and the like Scanning systems of this general type have been dis- 
closed, for example, in US Patent Nos. 4.251,798: 4,360.798; 4.369.361 ; 4,387,297; 4,409,470 and 4.460.120, all of 
which have been assigned to the same assignee as the instant application. 

Most bar codes presently used contain only five or six letters or digits, no more than a typical vehicle license plate. 
25 In view of the relatively small amount of data contained in a typical linear bar code, the most typical applications of a 
bar code is to use the encoded data merely as an index to a file or data base associated with the computer system com- 
prehensive information is available. 

As noted above, the contrasting parallel bars and spaces (referred to herein as "marks") or typical optically-detect- 
able bar codes have varying widths. Generally, the bars and spaces can be no smaller than a specified minimum width. 
30 termed the code's "unit" (or "x dimension" or "module"). While the theoretical minimum unit size is the wavelength of the 
light being used to read the bar code, other practical limitations exist. Among those limitations are the desired depth of 
field of the reading equipment, the limitations of a given printing process, and the robustness of the printed image to be 
coneclly read despite dust, dirt, and minor physical damage. 

The bar code symbols are formed from bars or elements typically rectangular in shape with a variety of possible 
35 widths. 

The specific arrangement of elements defines the character represented according to a set of rules and definitions 
specified by the code or "symbology" used. TTie relative size of the bars and ^aces is determined by the type of coding 
used, as is the actual size of the bars and ^aces. The number of characters per inch represented by the bar symbol is 
referred to as the density of the symbol. To encode a desired sequence of characters, a collection of element arrange- 
40 ments are concatenated together to form the complete bar code syn^ol, with each character of the message being rep- 
resented by its own corresponding group of elements. In some symbologies as a unique "start" and "stop" character is 
used to indicate where the bar code begins and ends. A number of different bar code symbologies exist. These sym- 
bologies include UPS/EAN, Code 39, Code 93. Code 128, Ckxlebar, and Interleaved 2 of 5. 

45 1 .2 Symbologies of (n,k) Type 

Some bar codes are referred to as belonging to the (n,k) family defined by Savir and Laurer in "The Characteristics 
and Decodeability of the universal Product Code, "IBM Systems Journal, Vol. 14, No 1,1973. A code of the (n.k) type 
represents characters uniquely by a string of n bits each containing k runs of one bit (i.e., k bars) and k runs of zero bits 
50 (i.e.. spaces). An (n,k) code is decodable in both directions, i.e., by scanning it either fonwards or backwards. Such bar 
codes are often referred to by numbers n and k; for example, the well-known Code 93 derives its name from this (n.l^ 
notation, i.e., n = 9 and k = 3. The UPC code Is an example of a (7.2) code. I.e., n = 7 and k = 2. 

1.3 Prior Tw -Dimensionai Bar Codes 

55 

Known two-dimensional bar codes exist that are extensions of one-dimensional bar codes, in that one-dimensional 
bar codes are stacked with horizontal guard bars between them to increase the density. An example of such bar codes 
is seen in U.S. Patent No. 4,794.239, to Aliais. 
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An obstacle to increasing the density of two-dimensional bar codes is the need for a certain minimum height in the 
vertical direction. A minimum height is needed to ensure that a human operator can keep a "scan line: (i.e., the path of 
a given scanning motion, such as that achieved by passing a hand-held wand across a bar code) within the area of a 
single bar-code row. Figure 1 1llustrates this difficulty: scan lines 1 0 J 1 and 1 2 present identical exemplar paths of, e.g. , 
5 hand-held wands over the bar cod 1 5, 1 6, 1 7. It will be seen that with a tall bar code 1 5, the scan lines 1 0 all stay within 
the confines of one bar code row, whereas with shorter bar codes 16 or17, the scan lines 1 1 and 12 cross from one 
row to another. 

Another limitation seen in some known two-dimensional bar codes is the use of fixed maps to translate from code- 
words to characters. The fixed maps restrict the flexibility of applications. For example, the well-known Code 49 has six 
10 fixed maps (i.e., six modes) to translate a codeword numerically or alphanumerically. 

Although such two dimensional bar codes provide some increase in the storage capacity, such codes are still used 
as indices for file look-up. rather than as a complete data file in itself. 

Still another drawback of some known two-dimensional codes is the need for a fixed number of codewords per line 
(referred to here as a "row") and the limitation of a maximum number of rows. For instance, Ck)de 49 (a bar code gen- 
15 erally in accordance with the aforementioned Allais '239 patent) has 4 codewords per row and 8 rows maximum. 

Yet another problem is the lack of flexibility in choosing a suitable security system. (The term "security" is commonly 
used to refer to confidence in accuracy or correctness; it is usually specified by a misdecode rate, e.g., in errors per mil- 
lion.) Code 49, for example, provides a very high level of security while sacrificing about 30% of its codewords on aver- 
age for checking errors. In some applications however, a lesser degree of security may be an acceptable trade-off in 
20 return for a greater codeword density; the ability to vary the security would be advantageous. 

The closest prior art is represented by US-A-4794239 relating to a multitrack bar code symbol and an associated 
decoding method. That document discloses a method of reading and decoding a machine readable symbol, the symbol 
including a plurality of adjacent individual code words having a detectable nf\ark/space pattern; the code words together 
defining, when taken in sequence, an encoded version of the data to be decoded, the method comprising: 

25 

(a) scanning and reading the codewords, not necessarily in the said sequence; 

(b) calculating, for each codeword X, a discriminator function f(X); 

(c) dividing the scanned codewords into a plurality of partial scans; 

(d) reaeating the said sequence by stitching together the partial scans; and 

30 (e) decoding the codewords and outputting or storing the sequenced decoded data. 

2. Summary of the Invention 

The present invention enat)les the use of an improved high-density two-dimensional symbology, as well as a f lexi- 
35 ble method for using the symbology to encode and decode data. The symbology may be used to create a nonvolatile 
read-only memory, which in turn may be used in a conputer system. 

Prior codes have been restricted in terms of information capacity or density. The present invention allows the use 
of symbologies which may achieve storage capacity of up to 1 kilobytes of memory within an area of one to four square 
inches. The significance of such a memory one should not be underestimated - It represents about 250 English words. 
40 about the size of a page or screen display. As an information unit, such unit is most suitable for many applications. 

2.1 Summary of Label Row-Wise Organization 

A suitable exemplary two-dimensional label for use with the method and apparatus of the invention rray comprise 
45 multiple rows of codewords; that is, the term "label" is used here to mean a complex marking of specified dimensions 
that includes a number of codewords organized in rows. Each codeword is a mark pattern comprising a plurality of ele- 
ments or marks; the marks can be of various heights, as in a bar code, or can be of a relatively small height to form a 
"dot code". Not just any mark pattern can constitute a codeword, however; each codeword belongs to a specific family 
or "set" of mark patterns that conforms to a particular descriptive rule about some characteristic of each mark pattern, 
so e.g., a rule about the width of each mark and the total width of each mark pattern. 

The codewords in any two adjacent rows are written in mutually exclusive subsets of the mark-pattern set (although 
in some embodiments the union of the subset is not exhaustive of the set itself). In particular, each subset of the mark- 
pattern set is defined so that It includes, as valid codewords for that subset, only those mark patterns that satisfy certain 
discriminator-function crit ria. 

55 Such row-wise usage of alternating subsets of codewords, grouped according to discriminator-function criteria, 
permits quick determination whether a row has be n crossed, without the need for a horizontal guard bar. This is. for a 
given scanned codeword in a label, determination of the discriminator function indicates whether the codeword comes 
from the same row as the previously-scanned codeword or from a different row (that is, whether the scan line has 
crossed between rows as illustrated in Figure 1). 
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Detection of line-crossing permits "stitching" of partial scans of particular rows into a map (e.g., in memory) of the 
label. The stitching process is roughly analogous to stitching a number of pieces of colored fabric into a predesigned 
quilt that displays, e.g., a picture: as each "piece" Is required by the scanning process. It is incorporated piecewlse into 
the appropriate point of the label. 

5 For example, suppose that confutation of the appropriate discriminator functions reveals that a scanning pass has 
scanned the first half of row 1 and the second half of row 2 of a label such as is shown in Figure 3. Assume that the 
respective longitude of the scanned data with respect to the ends of the label are known, e.g., through detection of start- 
and/or stop-codes. The knowledge that a row boundary has been crossed permits all the scanned data from the scan- 
ning pass to be Incorporated into the respective proper rows of the label map at the respective proper longitudes 

10 (assuming no scanning or decoding errors); the data from the scanning pass need not be discarded merely because 
the data did not come from a single desired row. 

As another (greatly sinplified) hypothetical example, assume that a part of one row has been scanned and that the 
data "123456789" are Incorporated into the label map as a result. Further assume that a second scanning pass of that 
row is made, and that the data "SySQABCD" are decoded as a result. If the overlapping portion if any between the two 

15 scanned data "pieces" - in this case, the "6789" portion - can be determined (e.g., with string-matching techniques such 
as described below), then the remainder of the later-scanned data can be approximately incorporated into the label 
map (In this case, the "ABCD" portion). 

Consequently, the operator need not be scrupulously careful to sweep the wand over the label one row at a time; 
virtually any scanning pass that includes either a row's start code or a stop code, or that can somehow be determined 

20 to overlap with data already incorporated in the label map, will yield usable data (assuming no coding or decoding 
errors). Such a label thus advantageously Increases the density of information by permitting height reductions in the 
codewords. 

2.2 Summary of Organization of Codeword Subsets 

25 

As noted, above, a key feature of the invention Is the use of different codeword subsets, preferably in different rows, 
each subset satisfying certain discriminator-function criteria. In one embodiment described here for Illustrative pur- 
poses, a (17,4) symbology is used. A discriminator function is used to divide the 1 1 ,400 available mark patterns in that 
symbology into three mark pattern subsets of 929 codewords each. 

30 The discriminator function may take as Its inputs the various widths of the on- and off marks of a mark pattern (e.g. , 
optically detectable bars and spaces) and may provide as an output a number from 0 to 8. Three subsets may then be 
selected whose discriminator function values are 0, 3, and 6, respectively, and whose mark widths meet certain other 
criteria. Each subset thus comprises a collection of codewords, alt of whose discriminator functions are both equal to 
each other and readily distinguishable from those of the codewords in the other two subsets. 

35 The availability of 929 codewords in each subset, each with a unique discriminatory-function number, permits each 
codeword to be used to represent a two-digit number In base 30. This capability leads to several advantages. 

As shown in Figure 5, each digit of the two-digit base-30 number can be used in an "alpha mode" or in a "mixed 
mode"; that is, each digit can be mapped into a 30-place alphabetic translation table of into a 30-place mixed alphanu- 
meric translation table. In each of these 30 place tables, one or more digits are reserved for use as signals to change 

40 translation tables. 

Alternatively, each two^igit number can be used in a "numeric mode" or in a "user mode" that is. each number can 
be mapped Into a 929-place numeric translation table or into any of up to twenty-seven 929-place user-defined transla- 
tion tables. In each of these tables as well, one or more digits are reserved for use as signals to begin using a different 
translation table. 

45 

2.3 Summary of Two-Step Decoding lUlethod 

In the first step of the preferred method, when a codeword Is scanned, the discriminator function of the scanned 
codeword is computed to determine the codeword subset of which the scanned codeword is a member. A t-sequence 

50 number based on the width of the marks comprising the codeword Is also computed; that number is used as an entry 
point into a lookup table for the codeword subset in question. The lookup table yields a number from 0 to 928, which is 
parsed into a two-digit number in base 30. 

In the second step, the high- and low-order digits of the base-30 number are used to determine the symbolic mean- 
ing assigned to the codeword (which may include an instruction to change translation tables. 

55 The method of the invention thus advantageously permits the user to define multiple translation tables. In addition, 
the invention is not constrained by logical limits on the number of codewords per row nor on the number of rows. This 
gives the user freedom to lay out the symbology in areas of varying shapes. 
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2.4 Summary of Error Detection and Correction 

A row-oriented incremental en-or detection capability is provided through the use of a checksum codeword for each 
row. After completion of low-level decoding but before performance of high-level decoding, various checksum compu- 
5 tations are performed to test the accuracy of the scan. 

In addition, a 'Yinai" checksum codeword for the label as a whole is used for additional security. The use of these 
checksums permits a limited degree of error recovery, since the checksums reflect the information contents of each of 
the codewords in the label. That is, errors in decoding particular codewords can be corrected in some circumstances 
by "subtracting" the known correct codewords from the checksum, so to speak, thereby yielding the correct value for the 
10 erroneously decoded codeword. 

If the test results are satisfactory, the high-level decoding step is performed. 

2.5 Sumntary of System Implementation 

15 The present invention may be applied within a system for reading bar code symbols or the like, including a hand- 
held scanning unit in a lightweight, portable housing including a symbol-detection device for generating a laser beam 
directed toward a symbol to be read, and for receiving reflected light from such symbol to produce electrical signals cor- 
responding to data represented by the symbol; a data processing device for processing the data represented by the 
symbol having a state according to at least first and second different coding procedures; and a read-control device to 

20 actuate the symbol-detection device to initiate reading of a symbol; wherein the symbol includes at least two groups of 
codewords: each codeword representing at least one information-bearing character and being selected from among a 
TeTof valid mark patterns. Each mark pattern comprises a pattern of marks, each mark pattern being representative of 
encoded data according to one of a plurality of different coding procedures; the codewords in each group being selected 
from a subset of mark patterns, the subset for said group being defined by a specified rule for that group that differs from 

25 the rule specified for said a different group each coding procedure being a function of the state of the data processing 
device. 

3. Brief Description of the Drawings 

30 Figure 1 A Is an Illustration of a prior-art bar code symtx)logy 

Figure 1 B is an Illustration of a label in accordance with the present invention; 

Figure 2 is an Illustration of the relationship between an x-sequence and a t-sequence In a codeword comprising 
part of a label embodying the present invention; 

Figure 3 is an exemplar layout of an illustrative high density two-dimensional symbology design in accordance with 
35 the invention; 

Figure 4 is a block-diagram illustration of the use of alternate sub-symbologies in different rows of a multi-row label 
in accordance with the invention; 

Figure 5 is a table showing alternate translation modes for encoding or decoding codewords; 
Figure 6 is a state-machine diagram of aspects of a method for using the table shown in Figure 5; 
40 Figure 7 is a pictorial representation of a sequence of encoding a string of readable characters into scannable 
codewords: 

Figure 8 is a logic diagram of an illustrative circuit for computing a checksum for a row in a label embodying the 
Invention; Figure 9 shows a similar circuit for computing an additional checksum for the entire label. 
Figure 10 is a schematic Illustration of the layout of codewords within a label; 
45 Figures 1 1 through 13 are logic diagrams of illustrative circuits for performing error recovery in accordance with the 
Invention; 

Figures 14A through 14D, Figures 15A through 15D, and Figures 16A through 16D depict tables used for decoding 
codewords in three different sub-symbologies. 

Figure 17 is a C-language program that may be used to generate these tables; 
50 Figure 18 is a block diagram of a computer system using a nonvolatile electro-optical memory In accordance with 
the invention; 

Figure 19a, 19b, 19c, and 19d Is an alternative type of laser scanning pattern that may be used in connection with 
the present invention; 

Figure 20 is an alternative an^ngement of a bar code symbol; and 
55 Figur 21 is a cross-sectional view of an implementation of a hand-held laser scanner which may be used to imple- 
ment the present invention. 
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4. DETAILED DESCRIPTION OF SPECIRC EMBODIMENTS 
4.1 Stitching of Partial Scans 

5 The label of the invention proves especially useful for stitching together of partial scans. As noted above (and refer- 
ring to Figure 1). when scan lines 12 cross codeword rows in a label 17. the partial scans must be "stitched" or pieced 
together. For example, consider a retail store checkout counter where a sales clerk manually passes a hand-held wand 
over a multirow label. If the wand's travel does not run substantially parallel to the label, the scan line may pass from 
one row to another; parts of different rows are thus scanned, but neither row is scanned completely. 

10 Stitching entails building a map of each row of the label (e.g. in memory); successive passes of the wand result in 
a greater degree of filling in the map. It can be accomplished by using known string matching algorithms, such as dis- 
closed in D Sankoff and J B Kruskal, editors, Time Warps, String Edits, and Macro-molecules: The TTieory and Practice 
of Sequence Comparison. Addison-Wesley, Reading. Massachusetts, 1983. One such algorithm is described below. 

15 4.2 Partitioned Symbology 

Stitching is facilitated by using different sub-symbol ogies in alternate rows, selected so that the scanner can made 
a local decision on whether a row has been crossed. Using different sub-symbologies in alternate rows allows the elim- 
ination of horizontal guard bars seen in prior-art code symbologies, thus permitting high density of information. 
20 The illustrative embodiment of the present Invention utilizes an advantageous scheme for organizing codewords 
into readily distinguishable groups. The scheme makes use of the principle of coding theorem to pick only a fraction of 
available mark patterns as legal code words to increase decoding reliability; it can be applied to any of a number of 
labels. 

One such label, refen-ed to here as a ''PDF417'' label (for "Portable Data File 417'), is described as an illustration 
25 Of this invention. PDF417 is a (17,4) label of the (n.l^ type described above. Each codeword has 4 bars and 4 spaces 
with a total width of 17 modules. 

It can be shown that this code yields a set of 1 1,440 different combinations of mark patterns. To increase decoding 
reliability, only a fraction of these available mark patterns are used as valid codewords. 

30 4.3 Discriminator Function for Defining Subset Partition 

As a first step in selecting a group of mark patterns for such use for this particular code, the 1 1 ,440 mark patterns 
are partitioned into nine subsets or "clusters." by calculating a discriminator function f(X) for each mark pattern X: 

35 f(X) = (x -X 3+x g-x j] mod 9 

where x^.xs.xs and xj stand for the bars' widths, and X2.X4,X6 and xg stand for the spaces' widths. The discriminator 
function f(X) above is one of possible alternative equations used to sutxlivide the different possible combinations into 
nine different subsets. 

40 Further narrowing is performed on three of the nine subsets of mark patterns, namely the subsets in which f(X)=0, 
f(X)=3. and fpq=6 (sometimes called cluster(0) cluster(3) and cluster(6), respectively). The narrowing is performed in 
part by defining a "t-sequence" for each mark pattern. Each element tk of the t-sequence is conputed according to the 
formula: 

45 ^k^^k+^k+i where k=l 7 

The three subsets cluster(i) (where i = 0, 3, 6) are narrowed by selecting mark patterns where no mark width is 
more than six (where j = 1, ...,7),and where not^is more than nine (where k = 1 , 7). 

Thus, the three final subsets cluster(i) of the mark patterns X that are selected for use as code words can be sum- 
50 marized as follows: 

cluster (i) = {x= f(X) = i, xj ^6, t ^^9} 

where i = 0, 3, 6, j = 1 ..... 8. and k = 1, .... 7. After sorting each cluster by the t-sequence while suppressing duplicate 
55 entries, it can be shown that each cluster(i) includes at least 934 mark patterns. The closest prime nuntier to 934 is 
929; accordingly. 929 mark patterns are selected from each cluster(i) for use as codewords. (For convenience, the term 
"x-sequence," with respect to any given mark pattern, is defined as the number having its digits xiX2 ...Xg). 

The t-sequence of each codeword can be used to identify that codeword, since it can be shown that each such t- 
sequence is unique within the three subsets cluster{i). It will be apparent that only the first six digits of the seven-digit t- 
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sequence need be used to uniquely specify a codeword of the (1 7,4) type, since as illustrated in Figure 2, the value of 
the final t-sequence element Xy is completely determined by the first six elements ti and the fixed total Exj of the mark 
pattern. As an example, suppose that t^ =2. t2=4, t3=6, t4=7, t5=6, and t6=4; the t-sequence for that codeword would be 
246764. 

5 The partition just described has the advantage that, by computing fpc) for any scanned mark pattern, the mark pat- 
tern's membership (or non-membership) in a codeword subset can quickly be ascertained. Furthermore, since the t- 
sequence for each codeword is unique, computation of the t-sequence permits that value to be used in a lookup table 
to determine the symbolic meaning assigned to a scanned mark pattern that belongs to a codeword subset. 

Other equivalent discriminator functions f(X) may be constructed and used. Preferably, such a discriminator func- 

10 tion should partition the available mark patterns into clusters (not necessarily nine clusters) approximately uniform in 
size. In addition, the clusters selected for use as codewords preferably are equidistant In "error distance", that is, the 
probability that a codeword from any of selected clusters A, B, C, etc., will be mistaken for a codeword from another one 
of those clusters should be of the same order of magnitude regardless of which of the other clusters is considered. 

15 4.4 Generating Subsets of Codewords 

An example of a computer program for generating lists of codewords for the various clusters(i) is set forth in Figure 
1 7. The example program Is written for convenience in the well-known C programming language, although any suitable 
language may be used; the example program is used generally as follows: 

20 

1. The program of Figure 17 is used to generate 9 outputfiles. referred to here as out(i), where i = 0 8. Only the 

output files out{0), out(3). and out(6) are used; they may be renamed as "cluster" files cluster(O), cluster(3). and 
cluster(6), respectively. 

2. All three cluster files are conventionally sorted to remove ambiguous entries, i.e., to eliminate any mark pattern 
25 whose t-sequence is identical to the t-sequence of any other mark pattern. 

3. The cluster files cluster(3) and cluster(6) are conventionally filtered to remove those entries in which any t^ is 
wider than 9. 

4. In the cluster file c!uster(0), those odd entries (I.e., the first entry, third entry, etc) in which any tk is wider than 6 
are filtered out, as are those even entries in which any t^ Is wider than 7. This is an arbitrary restriction designed to 

30 help make cluster(0) approximately the same size as cluster(3) and cluster(6), inasmuch as without such a restric- 
tion cluster(O) would be larger than the other two. 

5. The first 929 t-sequences of each of the filtered cluster files are selected as the desired entries for the respective 
lookup tables. 

35 4.5 Multirow Label Using Alternating Codeword Subsets 

In the multirow label of the invention, each row uses codewords from a different subset than the rows immediately 
adjacent to it. This enables the scanner to recognise with a high degree of precision whether a scan line has crossed a 
row in the middle of a codeword, because if a row has been crossed, the codewords scanned will not yield the same 

40 f(X) as the previous row. 

A row of codewords in accordance with the invention may conveniently contain unique start and stop codes in the 
conventional manner whose x-sequences are, e.g., 81 1 1 1 1 13 and 71 121 1 13 respectively These start and stop codes 
are unique in that no other codeword in any cluster has the same t-sequence as either of them; furthermore, they are 
members of none of the final subsets of codewords because the required condition Xj ^ 6 for all j = 1, .... 8 is not true 

45 for those codes. The start code may be selected to have its widest bar away from the ensuing data codewords to reduce 
the possibility of intercodeword interference, as is the above start code; if desired, the stop code may be so selected as 
well. 

The height unit module ratio H (the ratio of the height of a codeword (or a row) to one module width) may be 

changed from label to label or even from row to row depending on the printing/scanner (system or channel) resolution, 
50 R, or on the need of various applications. Figure 3 shows the first and the last rows having H approximately equal to 1 0, 

the rows in between having H approximately equal to 3, and the resolution R being approximately equal to 10 mil. 
The first row of the multirow label uses cluster(O) codes, the second row cluster(3) codes, the third cluster(6) codes, 

the fourth cluster(0) codes, the firth cluster(3) codes, and so on. There Is no logical linnit on ttie nuniaer of codewords 

per row or the total number of rows. 
55 In the embodiment illustrated here, the first codeword in each row is dedicated for use as a row identifier and the 

last codewond in each row is a checksum. (The maximum number of rows is thus 929, i.e., the number of codewords in 

the dedicated cluster). It is of course possible to distinguish between fbn*vard scanning and backward scanning of the 

row by matching the start/stop codeword forwardly or backwardly. 
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4.6 Other Row-Wise Partitioning of Codewords 

It will be apparent to those of ordinary skill having the benefit of this disclosure that the invention is not limited to 
the specific mark patterns, discriminator function f(X), and t-sequence described above. The foregoing method of deriv- 
ing a symbology can be applied in a substantially similar manner to yield equivalent symbologies having other kinds of 
mark patterns. 

For example, labels can be constructed from bars of varying shades of gray or even from bars of a wide range of 
colors, instead of from black and white marks only. In such a label, a disaiminator function for dividing all possible mark 
patterns into mutually exclusive codeword subsets, and a t-sequence function for uniquely identifying each codeword 
within a subset, may be based on a readily detectable attribute of a mark such as its hue or its gray scale value as well 
as on the width of each mark (or in lieu of the width, or In combination with the width). 

It will likewise be apparent that broadly construed, the same principle encompasses the equivalent use of code- 
words of different colors (or shades of gray) in alternate rows. That is, all rows of a multi-row label could use the same 
subset of mark patterns as codewords, but in different colors or shades or orientations; the determination whether a row 
has been crossed would be made based on whether a color or shade or orientation change had occurred. 

4.7 Subset Organization for Two-Step Decoding 

In the illustrative, width-based errtoodiment described above, since each cluster(i) includes 929 codewords, each t- 
sequence in a cluster thus will correspond to a number from 0 to 928. The codewords in each subset can be organized 
according to a base 30 system in which one codeword, representing a number in base 30. Is used to signify two alpha- 
numeric characters. 

Codewords can be scanned and decoded as follows. When a codeword is scanned, its t-sequence is noted. The t- 
sequence is then used as Input to an initial, low-level decoding step; the output from the low-level decoding step Is a 
number from 0 to 928 which in turn is used as an Input to a high-level decoding st^. 

4.8 Initial Low-Level Decoding Step 

The low-level decoding step entails looking up the t-sequence in a table for the appropriate cluster to find a con^e- 
spondlng value. The table may be created as described above. Referring to Figure 14A (a lookup table for cluster(O)), 
for example, the t-sequence 246764 corresponds to the value 111. 

The actual circuitry for the lookup tables may be conventional; it will be appreciated by those of ordinary skill that 
the use of a prime number of codewords in a subset, e.g., 929, advantageously facilitates the design of the circuitry. 

4.9 Mode-Dependent High-Level Decoding Step 

The look-up value 1 1 1 from the foregoing example can be broken down into a two-number sequence in base 30, 
each number being in the range of 0-29 and having a high-level value Vh and a low-level value Vt_. The base-30 
sequence is computed as follows: 

= xdiv 30; and 
Vl =xmod 30. 

For the t-sequence used above, 246764, yielding a look-up value of 111 , the high level value is 3, and the low level 
value Is 21, since 1 1 1=3x30 + 21. Each of the high and low values (i.e., 3 and 21) is then evaluated by looking it up in 
a suitable (arbitrary) table, such as shown in Figure 5. 

The examplar table in Figure 5 shows 30 decoding modes, Including Alpha, Numeric, Mixed, ad User modes. The 
various User modes are designated as the modes in Figure 5 corresponding to columns 3 through 29 (with column 0 
being Alpha mode). 

In the illustrative embodiment, the Alpha mode is the default mode; therefore, the sample t-sequence 246784 ulti- 
mately translates into the two-letter sequence DV, via the lookup value 1 1 1 and the base-30 sequence 3.21 . 

It will be seen that the coding an-angement depicted in Figure 5 provides for mode switching that can be advanta- 
geously effected either within a single codeword or within a strong of codewords. The technique for invoking mode 
switching varies depending on the current decoder mode. 
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4.10 Examples of High-Level Decoding 

The state machine diagram in Figure 6 illustrates a high-level decoding process in accordance with the invention 
for the exemplar emkxxiiment. For convenience, a two-number sequence in base 30 is represented as "xxH xxL" or 

5 "(xxH, xxL)", where "xx" represents an arbitrary one or two-digit number. For example, a high-level value of 18 and a 
low-level value of 10 is depicted herein as 18H, 10L or as (18H, 10L). 

As an example, assume the decoder is currently in Alpha mode. As shown in Figure 5, changing from Alpha mode 
to Mixed mode required that either the high value or the low value of the two-digit base-30 sequence be equal to 28. If 
the high value is 28, then the low value is unimportant tor mode switching purposes; likewise, if the low value is 28, then 

10 the high value is unimportant for nfKXle switching purposes. 

For Alpha mode, a high value of 28 signals to the decoder that a mode switch to Mixed mode (depicted in Figure 5 
as "ms" or Mixed-mode switch) must be effected; therefore, the low value of the high value/low value pair will be inter- 
preted in the Mixed mode. A low value of 28 allows the decoder to interpret the high value of the high value/low value 
pair in the current mode, namely Alpha mode, and then to switch into Mixed mode. This mode switching technique 

15 allows a final value to be decoded in the current mode before switching to the next mode, therefore, eliminating waste 
resulting from using an extra high value/low value pair to insure that a final high value is interpreted in the current mode. 

With decoding being done in Alpha mode, a hypothetical value of 856 yields 28H 16L. i.e. a high value of 28 and a 
low value of 16 (since 856 = 28x30 + 16). The high value of 28 toggles the decoder into Mixed mode, and the low value 
16, when translated according to Mixed mode protocol, yields "1" (an exclamation point). 

20 To change from Alpha mode to User mode, a high value of 29 (depicted as "us" or User-mode switch) and any low 
value n within the range of 3 to 29 is required. Low values of 0, 1 , or 2 result in no mode switch, a switch to Mixed mode, 
or a switch to Numeric mode, respectively In contrast to switching from Alpha to Numeric or Mixed modes, a switch to 
a User mode cannot be done by a low value of 29; any such values are ignored. 

Switching between other modes is done in a generally similar manner, as shown in Figures 5 and 6. Refening to 

25 those Figures, a decoder in Numeric mode can only directly switch to Alpha mode or Mixed mode. To toggle from 
Numeric mode to Alpha mode a non-position dependent value of 927 is required, i.e., either a high-level value or a low- 
level value equal to 927 will effect the mode switch. Likewise, to toggle from Numeric mode to Mixed mode a non-posi- 
tion dependent value of 928 is required. It will be apparent that the numbers 927 and 928 are the last two positions in 
the Numeric mode, and are reserved for mode-switching characters for convenience. 

30 To change from User mode to one of the predefined modes (Alpha, Numeric or Mix©j) a high value of 29 and a low 
value within the range 0 to 2 is required. The low value in this combination corresponds to the predefined mode into 
which the decoder is switching (i.e. a low value of 0 corresponds to Alpha mode, a low value of 1 conesponds to Mixed 
mode and a low value of 2 corresponds to Numeric mode. 

For example, assume that the current mode is Alpha and that three consecutive codewords are to be decoded: 872, 

35 345 and 99. Translating into base 30, 872 yields a high level value of 29 and a low level value of 2 (872=29x30 + 2). The 
first codeword 872 thus defines a User mode into which the decoder is switching. Refemng to Figure 5, if the decoder 
is in Alpha mode and a high level value of 29 and a low level value of 2 are encountered (as in the example above), the 
decoder changes to Numeric mode. 

As another example, assume that the decoder is in Alpha mode and that the scanned codeword's lookup value is 

40 723. In this case Vh = 723 div 30 = 24, and Vl = 723 mod 30 = 3. Therefore, the decoded codeword is (24H,3L). Since 
the current mode is Alpha, Figure 5 yields (Y,D) as the respective values for the decoded codeword (24H,3L). 

Decoding of values in the Numeric mode differs from decoding of values in Alpha mode and Mixed mode. Decoding 
in Numeric mode treats a two-number sequence as a number in base 926. For example, suppose that the current mode 
is Alpha and that the following three codewords are encountered 872, 345 and 99. A base 30 conversion of the first 

45 codeword 872 yields H « 29 and L = 2. This sequence signals the decoder to switch from Alpha mode to Numeric mode. 
Switching to the radix-926 decoding system, the second and third codewords are decoded as (345 x 926) -i- 99 = 
319569. 

The User modes may be used with considerable flexibility. All or part of one or more modes may be used to repre- 
sent a special user-defined code; for exanple, frequently-occurring words, phrases, sentences, paragraphs, etc., can 
50 be assigned to respective positions within a User mode. A given phrase etc. , can be represented in the label as a single 
codeword (combined with a "us" mode-switch command if necessary). It will be apparent that a great many different 
words, phrases, etc., can be represented, e.g., in the coding scheme depicted in Figure 5 as illustrations. 

4.11 Encoding Method 

55 

An encoding procedure is the reverse process of the decoding procedure. For example, referring to Figure 6, a 
license plate number "HUD-329" when encoded yields the following strong of codewords: 230, 926. 843, 69. Each ele- 
ment of the original string ''HUD-329'' is located in Table 2 and translated according to proper mode protocol. The first 
four elements of the string are translated using Alpha mode. This results in H=7, U=20. D=3, and (hyphen) =26. 
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The last three elements may be translated using Mixed mcxle. To switch to Mixed mode from Aopha mode a Mixed 
Shift (28) character is needed. The Mixed-mode translation then results in 3=3, 2=2 and 9=9. The complete string Is 
thus 7 20 3 26 28 3 2 9. 

This string is partitioned into high value/low value pairs, with resulting pairs (7,20) (3,26) (28,3) and (2.9). Each of 
5 these pairs is encoded as a codeword. To encode a high value/low value pair, the high value is multiplied by 30, and the 
low value is added to the result of this multiplication. 

For example, the pair (7,20) is encoded by multiplying 7 times 30 and adding 20, yielding a result of 250. All four 
pairs are encoded in this manner; the resulting string is 230 116 843 69. The string is translated into codewords in 
accordance with the appropriate lookup table for the codeword subset in use. Assuming hypothetical ly that cluster(O) is 
10 in use, the string is expressed using the codewords corresponding respectively to t-sequences 335633 (for 230). 
255663 (for 116), etc. 

4.12 Checksum Computation 

15 A checksum and error recovery scheme provides a row-oriented incremental error detection capability and high 
primitive decoding reliability Within each row, a long polynomial division checksum scheme is used. 

For convenience, each i-th codeword may be refeaed to by a corresponding index number aj, i.e., by the result of 
the low-level decoding step discussed above for that codeword. Each codeword's Index number aj will thus have a value 
from 0 to 928; each codeword is referred to sometimes for convenience by its index number. 

20 Each row with codewords an-i. 3^.2 ao can be represented as a polynomial: 

a(x) = ao + aiX + a2x^ . . .+an,.,x"'^ 

This polynomial is referred to herein as the message polynomial, as discussed in, e.g., Shin Lin & D.J. Costello, Jr., 
25 Error Control Coding, 1983. 

A row checksum bro is defined as the remainder resulting from dividing the message polynomial a(x) by a generator 
polynomial (see ibid.): 

gr(x) = x + 926 

30 

Those of ordinary skill will recognize that 926 is the complement of 3 In a Galois Field based on 929, or GF(929). 

The checksum of each row can conveniently be computed using the checksum encoding circuit shown in Figure 8. 
In Figures 8 through 13. the circle-plus (modula addition), circle-X (modulo multiplication), and cirde-C (modulo com- 
plementation) symbols are defined over GF(929) as: 

35 

X (circleiDlus) y = (x + y) mod 929 

x (circle-X) y = (x * y) mod 929 

40 (circle-C) x = 929 - x 

where x and y are any numbers from 0 to 928. It will of course be recognized that the design and construction of actual 
circuitry is a matter of routine implementation by those of ordinary skill. Such circuitry consequently is not further dis- 
cussed here. 

45 To perform the checksum computation, the register bjo is initialized to 0. The input is a sequence of codewords' 
index numbers as in a row, fed one nuntoer at a time into the input. The input fans into the output line (e.g., to a label 
printer) ar\d the checksum encoding circuit simultaneously. 

As the first codeword is input, the circle-plus computation is performed with the codeword's number aj sequence 
and bro (i.e., 0) as operands. The output of that computation and the number 926 is fed to the circle-X computation; the 

50 input of that computation is complemented and stored in the b^o register. After all of the codewords in a row have been 
processed through the checksum encoding circuit, the complement of the final value of b^) is the checksum and is 
appended at the end of the row. The sequence of codewords for the row (e.g., as printed) is now ap.^, an.2, ao, 929- 
bro- 

A similar scheme is used to compute a structure checksum, one representing the entire label. For this second type 
55 of checksum, all codewords in tfie label as printed (9ncluding the codewords representing the checksums for each row 
except the last row) form the message polynomial, which may be expressed as: 

, . n-3 . n-z nm-a 


10 


EP0 733 991 A2 

where the coefficients are defined as in Figure 10, tracing backwardly from right to left and bottom to top. A different 
generator polynomial is used to calculate a remainder in a similar fashion as before, namely: 

g,()() = (x + 926)(x + 920) 

5 

Dividing the new message polynomial by this new generator polynomial results in a remainder b(x) = bgo +bsix • 
Complementing the coefficients of this remainder yields two parity-check codewords, which serve as a structure check- 
sum as discussed below. 

In implementation this division is accomplished by using a division circuit such as shown in Figure 9. The registers 
10 bgo and bgt are initialized as zeros. As soon as the message polynomial has entered the output and the circuit, the com- 
plements of the parity-check codewords are in the registers and are appended in the order bgi, bgo just before the 
checksum of the last row. Then the checksum b^) of the last row is computed and appended to the end of the last row, 
as shown in Figure 10. 

It will be noted that there are no user-definable codewords corresponding to the positions a^, j and a^^o- These 
15 positions are reserved for the codewords bg i ad bg q as shown in Figure 10. Thus, in a label with m rows and no code- 
words per row, the total number of user-definable codewords is nm-4m-2, i.e., the number of codewords per row times 
the number of rows, minus four codewords for each row (a start code, a stop code, a row number, and a row checksum), 
and also minus the two parity-check codewords (i.e., the structure checksum). 

20 4.1 3 Gross Error Detection 

Gross error detection may be accomplished as follows. At the beginning of the scanning process, all entries (e.g.. 
"slots" or "grid locations") of the map of the label are initialized to indicate unknown characters. 

The low -level decoding step, as applied to a signal generated by any given scanning pass, will generate a 
25 sequence of one or more index numbers, one for each codeword that was scanned. Each index number may be any 
number from 0 to 928, depending on the t-sequence of the corresponding scanned codeword. 

For each scanning pass, three arrays DA, CA, and FA are constructed (e.g., in memory in accordance with conven- 
tional techniques) to represent the codewords scanned in that pass: 

30 • A "decoding array" DA represents the index numbers that are obtained from the tables in Figures 1 4A through 1 6D 
arxJ that correspond to the scanned codewords. 
• A "cluster array" CA represents the clusters or subsets to which the respective scanned codewords belong. 

A "confidence array" FA represents the confidence existing in the accuracy of the decoding of the respective 
scanned codewords. 

55 

For example, a scanning pass and low-level decoding step may generate a decoding array DA comprising a 
sequence of index numbers such as (293, 321 , 209, 99, 679). The corresponding sequence of clusters might be (3. 3, 
0, 0, 0) indicating that the first two codewords were members of clusler(S) and the final three were members of clus- 
ter(0). This implies that the subsequence comprising the second and third codewords (represented by 321 and 209 in 
40 the array DA) bracket the point at which a row was crossed, i.e., that the two codewords are in two adjacent rows. 
Because such row-crossing subsequences frequently have higher en-or probability, they are assigned a relatively low 
weight in confidence array FA. In the example above, the confidence an-ay FA for the scanned codewords might be (3, 
1.1.3,3). 

Now suppose that a previous scanning pass had resulted in a decoding array DA of (293, 329, 222, 999, 999) for 
45 the same sequence of codewords, where 999 represents an unknown codeword whose confidence level is zero. Fur- 
ther assume that the confidence array FA for that previous scanning pass is (3, 3,1,0, 0), because the row was crossed 
between the third and fourth characters on that pass instead of between the second and third characters as hypothe- 
sized in the previous paragraph. 

A "voting" process may be used to compare the confidence arrays for the two scanning passes to determine which 
so results are more likely to be correct. For example, the voting rules may be as follows: 

1 . If two successive scans of a given codeword result in the same index number after low-level decoding, then the 
corresponding confidence figures in the two confidence arrays FA are added; 

2. In contract, if two successive scans result in different numbers for the same codeword, then (a) if one of the two 
55 index numbers has a higher confidence level than the other, the higher-confidence index nuntier "survives" and is 

filled into the decoding array DA. but the confidence level for the corresponding position in the conf idenc array FA 
is reduced by the confidence level for the nonsurviving index number, (b) if both index numbers have equal confi- 
dence levels, then neither index number survives; instead the unknown-codeword index number 999 is used as the 
"surviving" index nuni)er and the confidence is reset to zero; and 
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3. If the index number a) for one scan of a given codeword is 999 (representing an unknown codeword) and an 
acceptable index number for the other scan (i.e., an index number from 0 to 928). then the acceptable index number 
is kept, and the confidence level of that index number remains the same. 

5 It will of course be appreciated by those of ordinary skill that a wide variety of conventional an^ay and memory-man- 
agement techniques may be used for creating and manipulating the an'ays DA, CA, and FA. For example, the decoding 
array DA might be the label map itself, with a temporary array being used to hold the index numbers a, for a new scan 
and with surviving Index numbers from that scan being written into the appropriate position in the array DA (or perhaps 
not written if the same index number is already represented at that position). In such an example the cluster an-ay CA 

10 and the confidence array FA might each be "shadows" of the decoding array DA, with as many positions in each as 
there are in the decoding array DA. 

When the decoding array DA has been filled with an acceptable index number aj for all codeword positions con-e- 
sponding to a particular row in the label, the representation of that row in the decoding array DA is set aside. That is, 
regardless of the confidence that exists about the accuracy of the contents of the decoding array DA, once the row has 

15 been decoded to indicate acceptable index numbers for each codeword, no further decoding is done for codewords in 
that row; additional error detection proceeds as described below. 

4.14 Further Error Detection and Recovery by Checksumming 

20 Errors may still exist in the decoding array DA for a particular row even af ier that row is set aside. Before performing 
high-level decoding, !he redundant information stored in the row checksums and the label checksum can advanta- 
geously be used to detect and/or recover from errors in scanning any particular codeword by a process of elimination. 

Generally speaking, if all but one or two of the codewords in the entire label are known to be con-ect, the correct 
values of the unknown codewords can be computed by "subtracting" (so to speak) the values of the known codewords 

25 from the values of the checksums,-which of course reflect the values of all codewords, known and unknown. 

Errors in any particular row may be detected by using a syndrome divider such as shown in Figure 1 1 . The register 
dro is initialised to zero. After the index numbers a| of the scanned row are fed to the syrxirome divider, the register dfo 
indicates the detection result. If 6jq Is equal to zero, the corresponding row was con-ectly scanned and its image or map 
in memory can be locked; othenwise, an error occurred in the scanning and decoding of the row, and the row must be 

30 rescanned. If all codewords in the label are decoded ad check summKi without en-or, then the following error recovery 
step can be skipped. 

When the total number of still-unknown codewords is less or equal to two, a error recovery scheme as follows can 
be invoked. The unknown codewords first are replaced in the label map with zeros. A syndrome Sj is then computed for 
each 1 = 1,2. Since by hypothesis the position p^ of the unknown (i.e., erroneous) codewords is known, where v = 1 , 2, 
35 only the values of those unknown codewords need be computed. As a first step, an error value epy is computed for each 
error position p^ by solving the following system off matrix equations: 


rsi] 1-3"^ 3"'- 


If only one error exists, the system becomes overdetermined, that is, more information is present than is needed to 
solve the above matrix, which reduces to: 

46 


For an assumed one-en'or case, if the above matrix equation system is consistent (that is, if the foregoing two 
matrix equations yield the same solutions), then one error does indeed exist ad the solution of 3^^ Is the error value, 
i.e., the con-ect value of the unknown codeword. Othenwise, an undiscovered second en-or exists in the label, and the 
decoding result is rejected. 

55 Afler successfully solving for the error values, the complement of error values are filled into the corresponding 
unknown codewords' locations. Then the error detection computation is performed again for those rows containing 
unknown codewords. If no en-ors are detected, the decoding result then is taken as correct; othenwise, the decoding 
result is likewise rejected. 
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4.15 Nonv latile Memory and Computer System 

Referring to Figure 18, a nonvolatile electro-optical memory 100 may be created by marking a suitable substrate 
(e.g., paper) with one or more labels in accordance with the foregoing description. The memory 100 may be combined 
5 with a fixed or movable scanner 1 10 for use as a storage device for a suitably programmed computer such as a proc- 
essor 120. 

For example, a robot might have an on45oard computer programmed to control the robot to perform simple tasks, 
such as selectively moving an object 130 by means of a manipulator 140. An on-board scanner 1 10 might operate as 
the robot's "eyes" for reading labels of the kind described above. In similar fashion, a conveyor system might include a 
10 fixed scanner 130 and a moving belt that served as the manipulator 140. The label preferably contains a list of instruc- 
tions for operating the robot, with the conputer on-board. The robot responding to data and instructions contained on 
the label. 

It will of course be recognized by those of ordinary skill (having the benefit of this disclosure) that the Invention is 
capable of being adapted to other uses and in other embodiments than the illustrative ones disclosed above. Further- 
15 more, the invention may be implemented in numerous specific architectures. A few examples are briefly mentioned 
below for Illustrative purposes: 

• The decoder of a conventional one-dimensional scanner could be reprogrammed to perform one or more of the 
functions described above, e.g., by replacing a read-only memory (ROM) chip containing the programming if the 

20 scanner is so constructed; 

• A scanning system could be built using a suitably programmed microprocessor or other computational unit to per- 
form one or more of the above functions. The programming could be loaded Into dynamic read-write memory 
(RAM), or could be "burned" into read-only memory (ROM) either on-board or out-board of the microprocessor; 

• A scanning system could be built using a computation unit specially designed to perform the functions described 
25 above; 

• parallel processing technology could be used to partition the work of decoding the various parts of a label; 

and so forth. The actual design and construction of any particular implementation is a matter of routine for those of ordi- 
nary skill having the benefit of this disclosure, the details of which are not further discussed here. 

30 Referring to Figure 1 8, a computer system including a nonvolatile memory 1 00 of the type described could be used 
in a number of applications. As an Illustrations, an overnight package delivery service (e.g., Federal Express, UPS, 
Purolator, and the like) might have certain of its package-sorting functions automated through the use of memories 100 
in the form of printed labels In accordance with the foregoing, applied to packages such as the object 1 30 shown in the 
figure. In one such possibility, package shippers would fill out a waybill 1 00 by responding to queries posed by a suitable 

35 computer program. The program's printed output (e.g., on a laser printer or dot matrix printer) might include both a 
human-readable destination address and a label 100 as described above in which that information was encoded in 
scannable form. The shipper would affix the printed waybill 100 to the object 130 being shipped. (Other information 
such as the shipper's telephone nunijer and the like couW likewise be so encoded.) One of the key advantages of the 
high data capacity memory 100 of the present Invention is that it may be created at the warehouse or loading dock by 

40 an inexpensive printer so that updated or corrected information may be applied at the point of shipment. The fact that 
the memory Is merely a paper label means that it is inexpensive and disposable. Thus, the present invention may be 
implemented in conjunction with a portable terminal and thermal printer to create and print a label, even in a remote 
location. Such a portable terminal , connected to scanner, allows the user to scan, print, and apply the label to the article 
quickly and inexpensively At various points during shipment, suitable rotx)ts could read the label 1 00 and, using manip- 

45 ulators 140, direct the object 130 appropriately; e.g., a scanner 110 could read the memory 100 to generate a signal; 
based on the content of that signal, a manipulator 140 controlled by a processor 120 could move the object 140 as 
appropriate. 

A similar arrangement could be used in a warehouse Inventory control system. A label of the type described could 
be printed or otherwise applied to or inscribed on one or more sides of a shipping carton or directly to merchandise. The 

50 label might have encoded therein as much information as desired about the specific item, e.g., its type, color, dimen- 
sions, weight, point of manufacture, lot number and so forth. A suitable robot could be used as an order-filling machine 
by moving within the warehouse and, using Its scanner, searching for merchandise whose label indicates that it 
matches a specified order. (Searching could of course be in accordance with techniques now known or hereafter devel- 
oped.) It will be apparent that this arrangement would permit information about specific merchandise items to be stored 

55 locally at th merchandise itself. 

Another feature of the present invention is to utilize the bar code according to the present Invention so that it may 
be affixed to an article as a means of identifying that article and associating information with the article much like a 
"read-only memory" or identification tag implemented in so called RF ID systems. One such implementation is to print 
a variety of different bar code symbols which are available in easily disposable and aff Ixabte format so that Information 
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may be easily and quickly affixed to the article. One example of an application is in connection with the repair and serv- 
ice of equipment. The use of a service record is useful for quality control and documentation purposes, but it is often 
impractical to store detailed written records with the equipment. The use of a high density, encoded service report 
affixed to the equipment in the form of a two dimensional bar code is especially advantageous. Th service technician 
may select the appropriate PDF label from a set of labels corresponding to repairs performed, and attach the label to 
the repaired equipment. If the equipment is returned for subsequent repairs, the service technician has the conplete 
service history attached to the equipment in only a few square inches. 

Such local storage couki advantageously take the place of a separate file of information about the item, e.g. , stored 
in a computer database and keyed to a bar-code serial number on the item. Local storage would reduce the problem of 
dealing with "orphan" merchandise whose serial numbers were not known to the computer database. In addition, it 
would permit rapid in-processing of newly-received merchandise shipments, in that complete information about the new 
merchandise could be scanned into the warehouse's Iriformation system, obviating the need for the shipper to generate 
and transmit a separate information file (e.g., on a cx)mputer tape or by hard copy) about the specified items being 
shipped. This would similarly be advantageous in, e.g., libraries or other organizations that regularly received ship- 
ments of books or similar objects that required cataloguing. 

Another example, a nonvolatile memory and scanner system could be used for enhanced searching of microfilm 
rolls or microfiche sheets. Assume that a large body of text and/or graphical information Is stored photographically on a 
roll of microfilm. An example of such information might be the thousands of documents - printed, typed, handwritten, 
drawn, or a combination thereof - that can be involved in a large litigation. Known computerized litigation support sys- 
tems permit paralegals to summarize each document page in a database: for each document page, selected informa- 
tion from the database could be inscribed as a label in accordance with the foregoing on the corresponding frame of 
microfilm, in a corner or other appropriate location. 

A microfilm reader could be equipped with (a) input means such as a keyboard by which a user could specify 
search criteria (e.g., in Boolean logic); (b) a fixed scanner to read microfilm labels as the microfilm was scrolled; and (c) 
control means to determine whether a given microfilm frame satisfied the specified search criteria. The user would then 
be able to view documents conveniently In the case of multiple-reel document collections, a master index or indexes 
could be encoded on a separate reel; output means such as a CRT or an LCD or LED display could be used to instruct 
the user as to which reel to mount to locate the specific document desired. 

For example, a microfilm reader with a scanner might be designed to be coupled to and controlled by a conven- 
tional desktop, laptop, or notetjook computer in a conventional manner as a peripheral device (or the essentials of such 
a computer could be built into the reader). The computer would not need to have the entire document-summary data 
base available on disk storage, since the miaofilm itself would contain the necessary information; It would suffice if the 
computer was programmed (e.g., in ROM) to perform the desired search functions using the label-encoded data from 
the microfilm. 

Still another feature of the present imention is to provide a m^hod for processing information by optically scanning 
indicia on the surface of a substrate, the indicia including a plurality of codewords scanned sequentially and organized 
into at least two ind^endent scanning paths, each codeword being either an information codeword or a control code- 
word, and each information codeword corresponding to at least one information-containing character. A plurality of dif- 
ferent mapping functions are provided each associating the code word with one character out of a set of different 
characters, with only one mapping function being active at any given time. Each codeword In any one scanning path is 
distinct from any codeword in an adjacent scanning path. Using such a codeword data structure, the method includes 
the steps of: determining whether a scanned codeword is an information codeword or a control codeword; decoding the 
codeword according to the mapping function if said codeword is an information codeword; and processing the codeword 
if the codeword is a control codeword. If the codeword is a control codeword, it identifies a new mapping function, and 
processing of subsequently scanned codewords take place using the new mapping function. 

As an example of the different scanning paths that may be used, and a different organization of the codewords, ref- 
erence is made to Figures 19 and 20. 

Figure 19a, 19b, 19c, and 19d is an alternative type of laser scanning pattern that may be used in connection with 
the present invention. 

The present invention may be implemented in a hand-held, laser-scanning, bar code reader unit such as illustrated 
in Figure 21. This hand-held device of Figure 21 is generally of the style disclosed in U.S. Patent 4,760,248, issued to 
Swartz et al, assigned to Symbol Technologies. Inc., and also similar to the configuration of a bar code reader commer- 
cially available as part number LS 810011 from Symbol Technologies, Inc. Alternatively, or in addition, features of U.S. 
patent 4,387.297 issued to Swartz et al, or US. Patent 4,409.470 issued to Shepard et al, both such patents assigned 
to Symbol Technologies Inc, may be employed in constructing the bar code reader unit of Figure 21. These patents 
4,760.248, 4,387.297 and 4,409,470 are incorporated herein by reference. A outgoing light beam 151 is generated in 
the reader 100. usually by a laser diode or the like, and directed to impinge upon a bar code symbol a few inches from 
the front of the reader unit. The outgoing beam 151 is scanned in a fixed linear pattern, or more complex pattern such 
as shown in Figure 19 may be employed and the user positions the hand-heW unit so this scan pattern traverses the 
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symbol to be read. The use of a central dark portion, such as in Fig. 19d, may be used tor aiming, a other visual tech- 
niques associated with alignment. Reflected light 152 from the symbol is detected by a light-responsive device 146 In 
the reader unit, producing serial electrical signals to be processed for identifying the bar code. The reader unit 100 is a 
gun shaped device, having a pistol-grip type of handle 153 and movable trigger 154 is employed to allow the user to 

5 activate the light beam 151 and detector circuitry when pointed at the symbol to be read, thereby saving battery life if 
the unit is self-powered. A light-weight plastic housing 155 contains the laser light source, the detector 146, the optics 
and signal processing circuitry, and the CPU 140 as well as a battery 162. A light-transmissive window 156 in the front 
end of the housing 155 allows the outgoing light beam 151 to exit and the incoming reflected light 152 to enter. Tlie 
reader 100 is designed to be aimed at a bar code symbol by the user from a position where the reader 100 is spaced 

w from the symbol, i.e., not touching the symbol or moving across the symbol. Typically, this type of hand-held bar code 
reader is specified to operate in the range of perhaps several inches. 

As seen in Figure 21 , a suitable lens 157 (or multiple lens system) is used to collimate and focus the scanned beam 
into the bar code symbol at an appropriate reference plane, and this same lens 157 may be used to focus the reflected 
light 152. A light source 158 such as a semiconductor laser diode is positioned to introduce a light beam into the axis 

15 of the lens 157 by a partially-silvered min-or and oth^- lenses or beam-shaping structure as needed, along with an oscil- 
lating mirror 159 which is attached to a scanning motor 160 activated when the trigger 1 54 is pulled. If the light produced 
by the source 158 is not visible, an aiming light may be included in the optical system, again employing a partially-sil- 
vered mirror to introduce the bema into the light path coaxially with the lens 1 57. The aiming light, if needs, produces a 
visible-light spot which is scanned just like the laser beam; the user employs this visible light to aim the reader unit at 

20 the symbol before pulling the trigger 1 54. 

In real applications, either the length of bar code should be fixed, or an additional character should be placed in the 
bar code to indicate its length. If not. misdecodings may occur. 

If the length of the bar code is fixed, the performance of decoding using stitching might be better than that of decod- 
ing using a complete scan, because the reject rate and the misdecode rate is less in most good quality bar code (in 

25 cases that the quality of the bar code is very very poor, the misdecode rate may be greater, but never greater than 2K 
times, K is the number of the scans used for stitching). 

Although the present invention has been described with respect to multiple line bar codes, it is not limited to such 
embodiments. It is conceivable ttiat the method of the present inv^ion may also find application for use with various 
machine version or optical character recognition applications in which information is derived from other types of indicia 

30 such as characters or from the surface characteristics of the article being scanned. 

In all of the various embodiments, the elements of the scanner may be assembled into a very conrpact package 
that allows the scanner to be fabricated as a single printed circuit board or integral module. Such a module can inter- 
changeably be used as the laser scanning element for a variety of different types of data acquisition systems. For exam- 
ple, the module may be alternately used in a hand-held scanner, a tattle top scanner attached to a flexible arm or 

35 mounting extending over the surface of the table or attached to the underside of the table top. or mounted as a subcom- 
ponent or subassembly of a more sophisticated data acquisition system. 

The module would advantageously comprise a laser/optics subassembly mounted on a support, a scanning ele- 
ment such as a rotating or reciprocating mirror, and a photodetector component. Control or data lines associated with 
such components may be connected to an electrical connector mounted on the edge or external surface of the module 

4C to enable the module to be electrically connected to a mating connector associated with other elements of data acqui- 
sition system. 

An individual module may have specific scanning or decoding characteristics associated with it. e.g. operability at 
a certain working distance, or operability with a specific symbology or printing density. The characteristics may also be 
defined through the manual setting of control switches associated with the module. The user may also adapt the data 

45 acquisition system to scan different types of articles or Hie system may be adapted for different applications by inter- 
changing modules on the data acquisition system through the use of the simple electical connector. 
The following claims are intended to encompass all such uses, implementations, and embodiments. 
A nonvolatile electro-optical read-only memory includes a substrate on which is printed (or othenMse inscribed) a 
complex symbol or "label" with a high density two-dimensional symbology, a variable number of component symbols or 

50 "codewords" per row, and a variable number of rows. Codewords in alternating rows are selected from mutually exclu- 
sive subsets of a mark pattern such as a (17.4) mark pattern. The subsets are defined in terms of particular values of 
a discriminator function, which is illustrated as being a function of the widths of bars and spaces in a given codeword. 
In the illustrated embodiment, each subset includes 929 available codewords; that, plus a two-step method of decoding 
scanned data, permitting significant flexibility in defining mappings of human-readable symbol sets into codewords. The 

55 memory may be used in conjunction with a scanner and a suitable control system in a number of applications, e.g., 
robotic operations or automated microfilm searching. 
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Claims 

1 . A method of reading and deocxling a machine readable symbol, the symbol including a plurality of groups of code- 
words, arranged in a plurality of lines within the symbol, each group comprising a plurality of individual codewords 
having a detectable mark/space pattern; at least some of the codewords together defining, when taken in 
sequence, an encoded version of the data to be decoded, the method comprising: 

(a) scanning and reading the codewords, not necessarily in the said sequence: 

(b) calculating a function f(X) the value of which distinguishes the group containing X from at least one other 
group of codewords; 

(c) determining the line in which the codeword X lies at least partially by the value of f(X], and dividing the 
scanned codeword into a plurality of partial scans, each partial scan consisting wholly of codewords of one 
group; 

(d) reaealing the said sequence; and 

(e) decoding the codewords and outputting or storing the sequenced decoded data. 

2. A method as claimed in Claim 1 in which the function f(X) may take a plurality of discrete values, the line in which 
the codeword X falls being uniquely determined by f(X). 

3. A method as claimed in Claim 1 or Claim 2 in which the mark/space patterns within any given group are approxi- 
mately equidistant in terms of enor distance from the mark/space patterns within any other group. 

4. A method as claimed in Claim 1 in which the codewords are arranged in a plurality of adjacent rows within the sym- 
bol, the row in which the codeword X lies being determined at least partially by the value of f(X). 

5. A method as claimed in Claim 4 in which corresponding codewords in each group are aligned In a direction perpen- 
dicular to the rows. 

6. A method as claimed in Claim 4 or Claim 5 in which the codewords are scanned row-wise or at a skewed angle 
thereto, the codewords Xj (i = 1 ,2...) on scanning being assigned to a common row only for so long as f(Xi) remains 
constant. 

7. A method as claimed in Claim 4 arxl Claim 6 in which the values of f(X) uniquely discriminate between any code- 
word lying In a first row and any codeword lying in a second adjacent row. 

8. A method as claimed in Claim 7 in which the respective values of f(X) also uniquely discriminate between any code- 
word lying in the first or second rows, and any codeword lying in a third row, adjacent to the second row. 

9. A method as claimed in any one of the preceding claims in which each mark/space pattern comprises a plurality of 
bars and spaces in which f(X) is a function of the widths of the individual bars and/or spaces making up the code- 
word X. 

10. A method as claimed in Claim 9 in which each mark/space pattern has exactly lour bars and in which 

f(X) = (Xi -Xg + Xg-x^jmodg 

where: 

x-t = width of 1st bar 

X3 = width of 2nd bar 

X5 = width of 3rd bar 

X7 = width of 4th bar 

1 1 . A method as claimed in Claim 1 0 in which a scanned mark/space pattern is determined not to be a codeword if f (X) 
does not equal 0. 3 or 6. 

1 2. A method as claimed In any one of the preceding claims in which a scanned mark/space pattern is determined not 
to be a codeword if any of the marks or spaces making up the pattern are wider than a specified width limit. 
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13. A method as claimed in any one of the preceding claims in which a scanned mark/space pattern is determined not 
to be a codeword if the distance between the start of any one of the marks or spaces making up the pattern, and 
the start of the adjacent such mark or space, is greater than a specified limit. 

5 14. A method as claimed in any one of the preceding claims in which a scanned mark/space pattern is determined not 
to be a codeword if the pattern does not comprise exactly a given number of marks and spaces. 

15. A method as claimed in Claim 12 in which the total width of a valid codeword is 17 units, and the width limit is 6 
units. 

10 

16. A method as claimed in Claim 13 in which the total width of a valid codeword is 17 units, and the specified units is 
9 units. 

17. A method as claimed in Claim 14 in which the total width of a valid codeword is 17 units, and in which the said given 
15 number is 4 marks and 4 spaces. 

18. A method as claimed in any one of the preceding clainrs comprising calculating a t-sequence for the codeword X 
and decoding the codeword X according to the t-sequence and f(X); the t-sequence being defined as a sequence 
of N-1 digits tj where N is the total number of marks and spaces in the pattern and tj is equal to the measured dis- 

20 tance between the beginning of the ith mark or space and the beginning of the next following mark or space respec- 
tively (Figure 2). 

19. A method as claimed in Claim 18 in which the codeword X is decoded by looking up in a table in memory an index 
number which, for a given value of f(X) uniquely corresponds to the calculated t-sequence. 

25 

20. A method as claimed in Claim 19 including converting the index number into respective hight and low values, 
defined as follows: 

V H = (index number) div m 

30 

V L = (index number) mod m 

and decoding the codeword X as two consecutive items corresponding to entries in a further look-up table at 
addresses and Vl- 

35 

21. A method as claimed in Claim 20 in which m = 30. 

22. A method as claimed in any one of Claims 19 to 21 including the following steps: 

40 (a) maintaining in memory a plurality of look-up tables corresponding to a plurality of decoding modes (eg fig- 

ure 5); 

(b) maintaining a variable in memory representative of the decoding mode currently active; 

(c) when the index value for the codeword X. or the value of Vh or V|_, corresponds to a control character which 
specifies a new decoding mode, changing to the said new mode and updating the decoding mode variable. 

45 

23. A method as claimed in any one of the preceding claims when dependent upon Claim 4 including calculating a 
checksum for each row and determining that an error has occurred if the calculated checksum does not match a 
checksum provided by a checksum-codeword in the row. 

50 24. A method as claimed in Claim 23 including the following steps, for each row: 

(a) scanning the mark/space patterns within the row and decoding each recognised codeword where possible, 
to an index value; 

(b) storing the r spective index values in a decoding array (DA); 

55 (c) repeating steps (a) and (b) until an index number has been stored in the decoding an-ay for; 

(i) the row check sum codeword for the row; and 

(ii) all but one of the codewords in the row; and 
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(d) reconstructing the missing one codeword using the row checksum codeword. 

25. A method as claimed in Claim 23 Including the following steps: 

(a) scanning the mark/space patterns within a row and decoding each recognised codeword, where possible, 
to an index value; 

(b) storing the respective index values in a decoding array (D); 

(c) repeating steps (a) and (b) as necessary for each row, and for all rows until an Index number has been 
stored In the decoding array for: 

(i) a symbol checksum codeword; 

(ii) all but two of the codewords in the symbol; and 

(ill) the row check sum codewords for the rows having the missing codewords; and 

(d) reconstructing the missing codewords using the row checksum codewords and the symbol checksum code- 
word. 

26. A method as claimed in any one of Claims 23 to 25 including the following steps: 

(a) scanning the mark/space patterns and decoding each recognised codeword, where possible, to an index 
value; 

(b) storing the respective index values in a decoding array (DA); 

(c) determining a confidence level corresponding to each of the elements of the decoding array (DA) and stor- 
ing the confidence levels in a corresponding confidence array (FA); 

(d) re-scanning, re-decoding, and re-determining index values and corresponding confidence values; 

(e) updating the decoding array and the confidence array according to the index values and confidence values 
determined at step (d) and the values In the decoding and confidence arrays. 

27. Apparatus for reading and decoding a machine readable symbol, the symbol including a plurality of groups of code- 
words, arranged in a plurality of lines within the symbol, each group comprising a plurality of individual codewords 
having a detectable mark/space pattern; at least some of the codewords together defining, when taken in 
sequence, an encoded version of the data to be decoded, the apparatus including means for scanning and reading 
the codewords, not necessarily in the said sequence, means for decoding the code words and means for outputting 
or storing the sequenced decoded data; characterised by: 

(a) means for calculating a function f(X) the value of which distinguishes the group containing X from at least 
one other group of codewords; 

(b) means for determining the line in which the codeword X lies at least partially by the value of f(X), and for 
dividing the scanned codewords into a plurality of partial scans, each partial scan consisting wholly of code 
words of one group; and 

(c) means for recreating the said sequence. 
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353442 

307 

432234 

357 

436534 

407 

444377 

457 

343365 

258 

353433 

308 

432245 

358 

436545 

408 

444422 

458 

343665 

259 

353464 

309 

432236 

359 

436623 

409 

444433 

459 

344332 

260 

333542 

310 

432334 

360 

436634 

410 


460 

344343 

261 

355333 

311 

432343 

361 

43664S 

411 

444455 

461 

344354 

262 

335364 

312 

432336 

362 

436734 

412 

444466 

462 

344365 

263 

333633 

313 

432367 

363 

437634 

413 

444477 

461 

344432 

264 

353664 

314 

432445 

364 

437734 

414 

444533 

464 

344443 

265 

336542 

313 

432436 

363 

442244 

415 

444544 

465 

344454 

266 

336333 

316 

432467 

366 

442255 

416 

444555 

466 

34446 5 

267 

336364 

317 

432536 

367 

442266 

417 

444566 

467 

344543 

268 

336642 

318 

433223 

368 

442333 

418 

444644 

468 

344554 

269 

336653 

319 

433234 

369 

442344 

419 

444655 

469 

344565 

270 

356664 

320 

433245 

370 

442355 

420 

445322 

470 

344576 

271 

336733 

321 

433236 

371 

442366 

421 

445333 

471 

344654 

272 

357653 

322 

433267 

372 

442377 

422 

445344 

472 

344665 

273 

337733 

323 

433323 

373 

442444 

423 

445355 

473 

345432 

274 

365S52 

324 

433334 

374 

442455 

424 

445366 

474 

345443 

275 

365363 

323 

433345 

375 

442466 

425 

445422 

475 

345454 

276 

365663 

326 

433356 

376 

442555 

426 

445433 

476 

345465 

277 

366532 

327 

433367 

377 

442566 

427 

445444 

477 

345532 

278 

366563 

328 

433434 

378 

443233 

428 

44545S 

478 

345543 

279 

366652 

329 

433445 

379 

443244 

429 

445466 

479 

345554 

280 

366663 

330 

433436 

380 

443255 

430 

445522 

480 

345565 

281 

367732 

331 

433345 

381 

443266 

431 

445533 

481 

345576 

282 

422224 

332 

433556 

382 

443277 

432 

445544 

482 

345643 

283 

422235 

333 

434323 

383 

443333 

433 

445555 

483 

345654 

284 

422246 

334 

434334 

384 

443344 

434 

445566 

484 

345665 

283 

422335 

335 

434345 

383 

443355 

435 

445633 

485 

345754 

286 

422346 

336 

434356 

386 

443366 

436 

445644 

486 

346532 

287 

422357 

337 

434367 

387 

4434 3 3 

437 

445655 

487 

346543 

288 

422446 

338 

434423 

388 

443444 

438 

446422 

488 

346554 

289 

423324 

339 

434434 

389 

443455 

439 

446433 

489 

346565 

290 

423335 

340 

434445 

390 

443466 

440 

446444 

490 

346632 

291 

423346 

341 

434456 

391 

443477 

441 

446455 

491 

34664 3 

292 

423435 

342 

434534 

392 

443544 

442 

446522 

492 

346654 

293 

423446 

343 

434545 

393 

443555 

443 

446533 

493 

346665 

294 

423546 

344 

434 5 56 

394 

443566 

444 

446544 

494 

346754 

295 

424424 

345 

434645 

395 

443655 

445 

446555 

495 

347643 

296 

424435 

346 

435423 

396 

444222 

446 

446622 

496 

347732 

297 

424446 

347 

435434 

397 

444233 

447 

446633 

497 

347754 

298 

424457 

348 

435445 

398 

444244 

448 

446644 

498 

354442 

299 

424535 

349 

435456 

399 

444255 

449 

446655 

499 
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Table I : 

The t-s«quence 

toble. ClusterO 


t— seq 

vol 

t-seq 

vol 

t-seq 

vai 

t-seq 

vol 

t-seq 

vol 

446733 

500 

456643 

550 

533333 

600 

544445 

650 

j5422Z 

700 

447522 

501 

456654 

c c t 

551 

533346 

601 

544456 

051 

J54iii 

701 

447544 

502 

436743 

332 

533435 

602 

€AA^\A 

544334 

052 

554244 

702 

447633 

503 

457343 

553 

533446 

603 

544545 

633 

554255 

703 

447722 

504 

457643 

554 

534324 

^/\A 

604 

545323 

^ €A 

654 

554266 

^f\A 

704 

447744 

505 

457743 

555 

534335 

605 

545334 

655 

554322 

705 

453332 

506 

464442 

556 

534346 

606 

545345 

656 

554333 

706 

453343 

507 

4644S3 

557 

534424 

607 

545423 

657 

554344 

707 

453354 

508 

464464 

558 

534435 

608 

545434 

658 

554335 

708 

453365 

509 

464S53 

559 

534446 

609 

543445 

659 

354366 

709 

453443 

510 

464564 

560 

534535 

610 

345523 

660 

554422 

710 

453454 

5n 

46S442 

561 

535424 

611 

545534 

661 

554433 

711 

453465 

512 

465453 

562 

535433 

612 

545545 

662 

554444 

712 

453476 

513 

465464 

563 

535524 

613 

545634 

663 

554455 

713 

453554 

514 

465542 

564 

535333 

614 

546423 

664 

554466 

714 

453565 

515 

465553 

565 

536324 

615 

546434 

665 

554533 

715 

454332 

516 

465564 

566 

536624 

616 

546523 

666 

554544 

716 

454343 

517 

465653 

567 

542223 

617 

546534 

667 

554535 

717 

454354 

518 

466442 

568 

542234 

618 

546623 

668 

554644 

718 

454365 

519 

466453 

569 

542243 

619 

346634 

669 

555222 

719 

454432 

520 

466542 

570 

542236 

620 

347623 

670 

555233 

720 

454443 

521 

466553 

571 

542334 

621 

552233 

671 

555244 

721 

454454 

522 

466642 

572 

542343 

622 

332244 

672 

555255 

722 

454465 

523 

4666S3 

573 

3423 36 

623 

332233 

673 

533322 

723 

454476 

524 

467642 

374 

342367 

624 

332266 

674 

333333 

724 

454543 

525 

475552 

575 

342443 

623 

552277 

675 

353344 

725 

454554 

526 

476552 

576 

342436 

626 

552333 

676 

555355 

726 

454565 

527 

522225 

577 

343223 

627 

552344 

677 

555422 

727 

4546 54 

528 

522236 

578 

543234 

628 

552355 

678 

555433 

728 

455332 

529 

522247 

579 

543245 

629 

552366 

679 

555444 

729 

455343 

530 

522336 

580 

343236 

630 

552444 

680 

553455 

730 

455354 

531 

523325 

581 

343323 

631 

552455 

681 

555522 

731 

j 453365 

532 

323336 

582 

543334 

632 

552466 

682 

555533 

732 

1 455432 

533 

523347 

583 

543345 

633 

552555 

683 

555544 

733 

1 455443 

534 

523436 

584 

543356 

634 

553222 

684 

555555 

734 

455454 

535 

524425 

585 

543367 

635 

553233 

685 

555633 

735 

4 55465 

536 

524436 

586 

543434 

636 

553244 

686 

555644 

736 

455532 

537 

S25S25 

587 

543445 

637 

553255 

687 

556322 

737 

455543 

538 

532224 

588 

543456 

638 

553266 

688 

556333 

738 

455554 

539 

532235 

589 

543545 

639 

553322 

689 

556344 

739 

455565 

540 

532246 

590 

544223 

640 

553333 

690 

556422 

740 

455643 

541 

532257 

591 

544234 

641 

553344 

691 

556433 

741 

455654 

542 

532335 

592 

544245 

642 

5533S5 

692 

556444 

742 

456432 

543 

532346 

593 

544256 

643 

553366 

693 

556522 

743 

456443 

544 

532357 

594 

544323 

644 

553433 

694 

556533 

744 

4 56454 

545 

5J2446 

595 

544334 

645 

555444 

695 

556544 

745 

4565)2 

546 

533224 

396 

544345 

646 

553455 

696 

556622 

746 

4 56543 

547 

533235 

597 

544356 

647 

553466 

697 

556633 

747 

4 56554 

548 

533246 

598 

544423 

648 

553544 

698 

556644 

74g 

4566)2 

549 

533324 

599 

544434 

649 

553555 

699 

557422 

749 
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Toble I : The t-sequence toMe. Clu8ter3 


I acq 

VUl 


VUl 


VUl 


VUl 


VUl 

222363 

0 

234327 

50 

266224 

100 

323773 

150 

334685 

200 

222374 

I 

234338 

51 

266233 

101 

324642 

151 

334752 

201 

222383 

2 

234 J49 

32 

266246 

102 

324653 

152 

334763 

202 

222396 

3 

234762 

S3 

2662S7 

103 

324664 

153 

334774 

203 

222663 

4 

234773 

54 

266335 

104 

324673 

154 

334785 

204 

222674 

5 

234784 

55 

266346 

105 

324686 

155 

334863 

205 

22268S 

6 

234795 

56 

267324 

106 

324753 

156 

334874 

206 

222696 

7 

234873 

57 

26733S 

107 

324764 

157 

335752 

207 

222774 

8 

234884 

38 

267346 

108 

324775 

158 

335763 

208 

222783 

9 

235427 

39 

26743S 

109 

324864 

159 

333774 

209 

222796 

10 

235438 

60 

268424 

110 

325742 

160 

335852 

210 

223632 

11 

235862 

61 

268433 

111 

325753 

161 

335863 

211 

223663 

12 

235873 

62 

269524 

112 

325764 

162 

335874 

212 

223674 

13 

235884 

63 

277223 

113 

325775 

163 

335963 

213 

223683 

14 

23S973 

64 

277234 

114 

325853 

164 

336832 

214 

223696 

IS 

236327 

63 

277245 

115 

325864 

165 

336863 

215 

223763 

16 

236962 

66 

277256 

116 

326842 

166 

336952 

216 

223774 

17 

236973 

67 

2773J4 

117 

326853 

167 

336963 

217 

223785 

18 

244226 

68 

277345 

118 

326864 

168 

337952 

218 

223796 

19 

244237 

69 

278323 

119 

326953 

169 

343227 

219 

223874 

20 

244248 

70 

278334 

120 

327942 

170 

343238 

220 

223883 

21 

244259 

71 

278343 

121 

327953 

171 

343249 

221 

224732 

22 

244337 

72 

278434 

122 

332352 

172 

343662 

222 

224763 

23 

244348 

73 

279423 

123 

332563 

173 

343673 

223 

224774 

24 

244772 

74 

279434 

124 

332374 

174 

343684 

224 

22478S 

23 

244783 

75 

322433 

125 

332S85 

175 

343695 

225 

224796 

26 

244794 

76 

322464 

126 

332396 

176 

343773 

226 

224863 

27 

243326 

77 

322475 

127 

332663 

177 

343784 

227 

224874 

28 

245337 

78 

322486 

128 

332674 

178 

344227 

228 

224885 

29 

245348 

79 

322497 

129 

332685 

179 

344238 

229 

224974 

30 

24S437 

80 

322553 

130 

332696 

180 

344327 

230 

223832 

31 

243872 

81 

322564 

131 

332774 

181 

344338 

231 

225863 

32 

245883 

82 

322573 

132 

332785 

182 

344662 

232 

225874 

33 

246426 

83 

322586 

133 

333552 

183 

344673 

233 

225885 

34 

246437 

84 

322597 

134 

333563 

184 

344684 

234 

225963 

35 

246972 

85 

322664 

135 

333574 

185 

344762 

233 

225974 

36 

247526 

86 

322675 

136 

333585 

186 

344773 

236 

226952 

37 

255225 

87 

322686 

137 

333596 

187 

344784 

237 

226963 

38 

255236 

88 

322775 

138 

333652 

188 

344873 

238 

226974 

39 

255247 

89 

323542 

139 

333663 

189 

345327 

239 

233227 

40 

255258 

90 

323553 

140 

333674 

190 

345427 

240 

233238 

41 

255336 

91 

323564 

141 

333685 

191 

345762 

241 

233249 

42 

255347 

92 

323575 

142 

333696 

192 

345773 

242 

233662 

43 

256325 

93 

323586 

143 

333763 

193 

345862 

243 

233673 

44 

256336 

94 

323597 

144 

333774 

194 

345873 

244 

233684 

45 

256347 

95 

323653 

145 

333785 

195 

346862 

245 

233695 

46 

256436 

96 

323664 

146 

333874 

196 

346962 

246 

233773 

47 

257423 

97 

323675 

147 

334652 

197 

354226 

247 

233784 

48 

257436 

98 

323686 

148 

334663 

198 

354237 

248 

1 233795 

49 

258525 

99 

323764 

149 

334674 

199 

3S4248 

249 
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Toble I : The t-sequence tobie. Cluster3 


t"Seq vol 

t-seq 

vol 

t-seq 

vol 

t-seq 

vol 

t-seq 

vol 

354337 

250 

177<7A 

ion 


ISO 


400 

497221 

^ 7 r XX J 

4 so 

354772 

251 

^^^XX< 
42200J 


4^>#oO 

jji 


40t 

4Q7?14 

/X 

41 1 


252 

^17^ 17 
423432 

lrt7 
3U2 

411C47 

15^ 

441774 

40^ 

^vX 

4011171 

XJ 

4S7 

' JX 


253 

42>443 

101 

411S51 
4J 

15t 

J J J 

J JX 

401 

<77711 

^XXX J J 

411 


ISA 

423454 

304 

433504 

1<4 
3>4 

4##J03 

4A4 

9777 A4 
322244 


1 C C 1 -Jit 


423463 

303 

433375 


44#3 /4 


<777 << 
322233 

A<K 

435 


ZjO 

423476 

306 

433556 

KX 

356 

444C3x 

4U0 

<777XX 
322200 

x<x 
430 


7<7 

423487 

307 

433653 

357 

A A A^£^ 

444663 

407 

522277 

A £^ 
457 

^^^0 

7^fl 

423543 

308 

433664 

358 

A A A^'J A 

444674 

408 

522333 

A €0 

458 



423554 

309 

433675 

359 

A A A^ 

444752 

409 

322344 

A cn 
459 


20U 

423565 

310 

433764 

360 

AAA <V^^ 

444763 

410 

522355 

460 

365225 

261 

423576 

3ti 

434542 

361 

AAA ^^A 

444774 

A t t 

411 

A^^^ AA 

522366 

AA\ 

461 

1 JtC^ lit 

365236 

262 

423654 

312 

434553 

362 

444863 

412 

522377 

462 

365247 

263 

423665 

313 

434564 

363 

445652 

413 

522444 

463 

365336 

264 

424532 

314 

434575 

364 

445663 

414 

522455 

464 

366225 

265 

424543 

315 

434642 

365 

445752 

415 

522466 

465 

366230 

7XJC 
Z6O 

424554 

316 

434653 

366 

445763 

416 

522555 

466 


7#t7 

424565 

317 

434664 

367 

445852 

417 

523322 

467 

3663 30 

7^ 

424576 

318 

434675 

368 

445863 

418 

523333 

468 

36/325 

7iCQ 
2O7 

424643 

319 

434753 

369 

A A f t 

446752 

A t t\ 

419 

523344 

469 

3674 zj 

77n 

424654 

320 

434764 

370 

446852 

420 

523355 

470 

370224 

771 

LI \ 

424665 

321 

435642 

371 

446952 

421 

523366 

471 

J /Oz J J 


424754 

322 

435653 

372 

453227 

422 

523377 

A f ^ 

472 

J / 0x40 

771 
X /3 

425632 

323 

435664 

373 

453238 

A 

423 

A*%tA 1^ 

523433 

A 

473 

J f Oj J J 

77A 

X 

425643 

324 

a4 ^4 At 

435742 

374 

453662 

424 

€^tAAA 

323444 

A ^A 

474 


77^ 

425654 

325 

435753 

375 

453673 

425 

<77X <C 

523455 

A *VC 
475 

3 / / *3j 

77#k 
X rO 

425665 

326 

435764 

9^X 

376 

4536»4 

426 

C77^XX 

323466 

A ^X 

476 

3 ' '3x4 

777 

Iff 

42574 J 

327 

435853 

377 

453773 

427 

523544 

477 

3 / ' 335 

77a 

X /o 

425754 


436742 

378 

A g A '9^^ 

454227 

428 

523555 

A ^0 

478 

375324 

7 70 

X /y 

426732 

329 

436753 

379 

454327 

429 

524422 

479 

375424 

2oU 

426743 

330 

436842 

380 

454662 

430 

A A ^ ^ 

524433 

480 

357223 

7ft 1 
251 

426754 

331 

436853 

381 

454673 

431 

524444 

481 

357Z34 

197 

252 

426S43 

332 

437842 

382 

454762 

432 

524455 

482 

387245 

253 

427832 

333 

437942 

383 

454773 

433 

524466 

483 

387334 

284 

427843 

334 

442552 

384 

455662 

434 

524533 

484 

1 388323 

285 

432442 

335 

442563 

385 

455762 

435 

524544 

485 

i 388334 

286 

432453 

336 

442574 

386 

455862 

436 

524555 

486 

; 389423 

287 

432464 

337 

442585 

387 

464226 

437 

524644 

487 

! 422343 

2M 

432475 

338 

442596 

388 

464237 

438 

525522 

488 

1 422354 

289 

432486 

339 

442663 

389 

464772 

439 

525533 

489 

j 422365 

290 


34U 

^7x7 A 


4X<77X 
<*OjX XQ 


97994J 

ion 

1 422376 

291 

432353 

341 

442685 

391 

465326 

441 

525555 

491 

422387 

292 

432564 

342 

442774 

392 

475225 

442 

525633 

492 

422443 

293 

432575 

343 

443552 

393 

475236 

443 

525644 

493 

422454 

294 

432586 

344 

443563 

394 

476225 

444 

526622 

494 

422465 

295 

432664 

345 

443574 

395 

476325 

445 

526633 

495 

422476 

296 

432675 

346 

443585 

396 

486224 

446 

526644 

496 

422487 

297 

433442 

347 

443652 

397 

486235 

447 

526733 

497 

422554 

298 

433453 

348 

443663 

398 

487224 

448 

527722 

498 

422565 

299 

433464 

349 

443674 

399 

487324 

449 

527733 

499 
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Table I : 

The t-*sequence 

table. Cluster3 


f »e Art 

vol 

t-sea 

val 

t-sea 

val 

t-sea 

val 

* VI* 

t— sea 

val 

532332 

500 

542453 

550 

SS4SS2 

600 

632444 

650 

643354 

700 

532343 

501 

542464 

551 

554563 

601 

632455 

651 

643365 

701 

532354 

502 

542475 

552 

554652 

602 

633222 

652 

643432 

702 

532365 

503 

542486 

553 

554663 

603 

633233 

653 

643443 

703 

532376 

504 

542553 

554 

554752 

604 

633244 

654 

643454 

704 

532387 

505 

542564 

555 

554763 

605 

633255 

655 

643465 

705 

532443 

506 

542575 

556 

555552 

606 

633266 

656 

643543 

706 

532454 

507 

542664 

557 

5SS652 

607 

633322 

657 

643554 

707 

532465 

508 

543442 

558 

555752 

608 

633333 

658 

644332 

708 

532476 

509 

543453 

559 

555S52 

609 

633344 

659 

644343 

709 

532554 

510 

543464 

560 

563227 

610 

633355 

660 

644354 

710 

532565 

511 

543475 

561 

563662 

611 

633366 

661 

644432 

711 

533332 

512 

543542 

562 

563673 

612 

633433 

662 

644443 

712 

533343 

513 

543553 

563 

564662 

613 

633444 

663 

644454 

713 

533354 

514 

543564 

564 

564762 

614 

633455 

664 

644532 

714 

533365 

515 

543575 

565 

574226 

615 

633544 

665 

644543 

715 

533376 

516 

543653 

566 

585225 

616 

634322 

666 

644554 

716 

533432 

517 

543664 

567 

596224 

617 

634333 

667 

644643 

717 

533443 

518 

S44442 

568 

623223 

618 

634344 

668 

645432 

718 

533454 

519 

544453 

569 

622234 

619 

634355 

669 

645443 

719 

533465 

520 

544464 

570 

622245 

620 

634422 

670 

645532 

720 

533476 

521 

544542 

571 

622256 

621 

634433 

671 

645543 

721 

533543 

522 

544553 

572 

622267 

622 

634444 

672 

645632 

722 

533554 

523 

544564 

573 

622334 

623 

634455 

673 

645643 

723 

533565 

524 

544642 

574 

622343 

624 

634533 

674 

646532 

724 

533654 

525 

544653 

573 

622356 

625 

634544 

675 

646632 

725 

534432 

526 

544664 

576 

622445 

626 

635422 

676 

646732 

726 

534443 

527 

544753 

577 

623323 

627 

635433 

677 

652442 

727 

534454 

528 

545542 

578 

623334 

628 

635444 

678 

652453 

728 

534465 

529 

545553 

579 

623345 

629 

635522 

679 

652464 

729 

534532 

530 

545642 

580 

623356 

630 

635533 

680 

652475 

730 

534543 

531 

545653 

581 

623434 

631 

635544 

681 

652553 

73 J 

534554 

532 

545742 

582 

623445 

632 

635633 

682 

652564 

732 

534565 

533 

545753 

583 

624423 

633 

636522 

683 

653442 

733 

534643 

534 

546642 

584 

624434 

634 

636533 

684 

653453 

734 

534654 

535 

546742 

585 

624445 

635 

636622 

685 

653464 

735 

535532 

536 

546842 

586 

624534 

636 

636633 

686 

653542 

736 

535543 

537 

552552 

587 

625523 

637 

637622 

687 

653553 

737 

535554 

538 

552363 

588 

625534 

638 

637722 

688 

653564 

738 

535632 

539 

552574 

589 

626623 

639 

642332 

689 

653653 

739 

535643 

540 

532585 

590 

632222 

640 

642343 

690 

654442 

740 

535654 

541 

552663 

591 

632233 

641 

642354 

691 

654453 

741 

535743 

542 

552674 

592 

632244 

642 

642365 

692 

654542 

742 

536632 

543 

553552 

593 

632255 

643 

642376 

693 

654553 

743 

536643 

544 

553563 

594 

632266 

644 

642443 

694 

654642 

744 

536732 

545 

553574 

595 

632277 

645 

642454 

695 

654653 

745 

536743 

546 

553652 

596 

632333 

646 

642465 

696 

655«'2 

746 

537732 

547 

553663 

597 

632344 

647 

642554 

697 

655542 

747 

537832 

548 

553674 

598 

632355 

648 

643332 

698 

655642 

748 

542442 

549 

553763 

599 

632366 

649 

643343 

699 

655742 

749 
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Toble I : The t-sequence toble. Cluster3 


t— sea 

vol 

t-seq 

vol 

t-seq 

vol 

t-seo 

vol 


662SS2 

750 

743255 

800 

762453 

850 

862343 

900 


662363 

751 

743322 

801 

762464 

851 

862354 

901 


6625"'4 

752 

743333 

802 

762553 

852 

862443 

902 


662663 

753 

743344 

803 

763442 

833 

863332 

903 


663SS2 

r54 

743355 

804 

763453 

854 

863343 

904 


663 S63 

755 

743433 

805 

763542 

855 

863432 

905 


663652 

756 

743444 

806 

763553 

856 

863443 

906 


663663 

757 

744222 

807 

764442 

857 

864332 

907 


6645S2 

758 

744233 

808 

764542 

858 

864432 

908 


6646S2 

759 

744244 

809 

764642 

859 

864S32 

909 


664752 

760 

744322 

810 

772552 

860 

872442 

910 


673662 

761 

744333 

811 

772563 

861 

872453 

911 


722224 

762 

744344 

812 

773552 

862 

873442 

912 


722235 

763 

744422 

813 

773652 

863 

873542 

913 


722246 

764 

744433 

814 

832224 

864 

942224 

914 


722335 

765 

744444 

815 

832235 

865 

952223 

915 


723324 

766 

744533 

816 

833324 

866 

952234 

916 


723335 

767 

745322 

817 

842223 

867 

953223 

917 


724424 

768 

745333 

818 

842234 

868 

953323 

918 


732223 

769 

74S422 

819 

842245 

869 

962222 

919 


732234 

770 

745433 

820 

842334 

870 

962233 

920 


732245 

771 

745522 

821 

843223 

87] 

962244 

921 


732256 

772 

745533 

822 

843234 

872 

962333 

922 


732334 

773 

746422 

823 

843323 

873 

963222 

923 


732345 

774 

746322 

824 

843334 

874 

963233 

924 


733223 

775 

746622 

825 

844323 

875 

963322 

925 


733234 

776 

752332 

826 

844423 

876 

963333 

926 


733245 

777 

752343 

827 

852222 

877 

964222 

927 


733323 

778 

752354 

828 

852233 

878 

964322 

928 ! 

733334 

779 

752365 

829 

852244 

879 


j 

733345 

780 

732443 

830 

852255 

880 


i 

733434 

781 

732454 

831 

852333 

881 


i 

734323 

782 

753332 

832 

852344 

882 



734334 

783 

753343 

833 

853222 

883 



734423 

784 

753354 

834 

853233 

884 



734434 

785 

753432 

835 

833244 

885 


i 

735423 

786 

753443 

836 

853322 

886 



735523 

787 

753454 

837 

833333 

887 : 



742222 

788 

753543 

838 

833344 

888 ! 



742233 

789 

754332 

839 

833433 

889 i 



742244 

790 

754343 

840 

834222 

890 : 



742255 

791 

754432 

841 

854233 

891 1 



742266 

792 

754443 

842 

854322 

892 ; 



742333 

793 

754532 

843 

854333 

893 j 



742344 

794 

754543 

844 

854422 

894 1 


j 

742355 

795 

755332 

845 

854433 

895 



742444 

796 

755432 

846 

855322 

896 




743222 

797 

755532 

847 

855422 

897 




743233 

798 

755632 

848 

855522 

898 




743244 

799 

762442 

849 

862332 

899 
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Toble I : The t-sequence tobie. Ctuster6 



vnl 

VUi 


VUI 


unl 

VUI 


VUI 


VQI 

2222)6 

0 

233357 

50 

244445 

100 

2555SS 

ISO 

268643 

200 

222247 

I 

233368 

51 

244456 

101 

256322 

151 

269632 

201 

222258 

2 

233379 

52 

244467 

102 

256333 

152 

269643 

202 

222269 

3 

233446 

53 

244556 

103 

256344 

153 

277442 

203 

222336 

4 

233457 

54 

245323 

104 

256355 

154 

277453 

204 

222347 

5 

233468 

55 

245334 

105 

256366 

155 

277464 

205 

212358 

6 

233557 

56 

245345 

106 

256377 

156 

277553 

206 

222369 

7 

234324 

57 

245356 

107 

256433 

157 

278542 

207 

222447 

8 

234335 

58 

245367 

108 

256444 

158 

278553 

208 

222458 

9 

234346 

59 

245378 

109 

256455 

159 

279642 

209 

222469 

to 

234357 

60 

245434 

110 

256466 

160 

ntUA 

210 

223325 

11 

234368 

61 

245445 

111 

256544 

161 

322237 

211 

223336 

12 

234379 

62 

245456 

112 

256555 

162 

322248 

212 

223347 

13 

234435 

63 

245467 

113 

257422 

163 

322259 

213 

223358 

14 

234446 

64 

245545 

114 

257433 

164 

322337 

214 

223369 

15 

234457 

65 

245556 

US 

257444 

165 

322318 

215 

223436 

16 

234468 

66 

246423 

116 

257455 

166 

322359 

216 

223447 

17 

234546 

67 

246434 

117 

257466 

167 

322772 

217 

2234S8 

18 

234557 

68 

246445 

118 

257533 

168 

322783 

218 

223469 

19 

235424 

69 

246456 

119 

257544 

169 

322794 

219 

223547 

20 

235435 

70 

246467 

120 

257555 

170 

323326 

220 

223558 

21 

235446 

71 

246534 

12t 

257644 

171 

323337 

221 

224425 

22 

235457 

72 

246545 

122 

258522 

172 

323348 

222 

224436 

23 

235468 

73 

246556 

123 

258533 

173 

323359 

223 

224447 

24 

235535 

74 

246645 

124 

258S44 

174 

323437 

224 

224458 

25 

235546 

75 

247523 

125 

23I5S5 

173 

323448 

223 

224469 

26 

235557 

76 

247534 

126 

1SS633 

176 

323872 

226 

224536 

27 

235646 

77 

247545 

127 

U8644 

177 

323883 

227 

224547 

28 

236524 

78 

247556 

128 

239622 

178 

323894 

228 

224558 

29 

236535 

79 

247634 

129 

2S9633 

179 

324426 

229 

224647 

30 

236546 

80 

247645 

130 

239644 

180 

324437 

230 

225523 

31 

236557 

81 

248623 

131 

239733 

181 

324448 

231 

225536 

32 

236635 

82 

248634 

132 

266332 

182 

324537 

232 

225547 

33 

236646 

83 

248645 

133 

266343 

183 

324972 

233 

225558 

34 

237624 

84 

248734 

134 

266394 

184 

324983 

234 

225636 

35 

237635 

85 

249723 

155 

26636S 

185 

325526 

235 

225647 

36 

237646 

86 

249734 

136 

266376 

186 

325537 

236 

226625 

37 

237735 

87 

255233 

137 

266443 

187 

326626 

237 

226636 

38 

238724 

88 

255244 

138 

266454 

188 

332225 

238 

226647 

39 

238735 

89 

255255 

139 

266463 

189 

332236 

239 

226736 

40 

244234 

90 

255266 

140 

266334 

190 

332247 

240 

227725 

41 

244245 

91 

255277 

141 

267432 

191 

332258 

241 

227736 

42 

244256 

92 

255333 

142 

267443 

192 

332269 

242 

233235 

43 

244267 

93 

255344 

143 

267454 

193 

332336 

243 

233246 

44 

244278 

94 

255355 

144 

267465 

194 

332347 

244 

233257 

45 

244334 

95 

255366 

145 

267543 

195 

332358 

245 

233268 

46 

244345 

96 

255377 

146 

267554 

196 

332369 

246 

233279 

47 

244356 

97 

255444 

147 

26SS32 

197 

332447 

247 

233335 

48 

244367 

98 

255455 

148 

268543 

198 

332458 

248 

233346 

49 

244378 

99 

255466 

149 

268354 

199 

333225 

249 
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Toble I : The t-sequence toble. Clusters 


t-seq 

vol 

t-seq 

VQ 

t-sea 

vol 

t—sea 

vnl 


Vu 

333236 

250 

344246 

300 

355256 

350 

366266 

400 

387442 

450 

333247 

251 

3442S7 

301 

355267 

351 

366322 

401 

387453 

451 

333258 

252 

344268 

302 

355323 

352 

366333 

402 

388542 

452 

333269 

253 

344324 

303 

355334 

353 

366344 

403 

422227 

453 

J33325 

254 

344335 

304 

355345 

354 

366355 

404 

422238 

454 

333336 

255 

344346 

305 

355336 

355 

366366 

405 

422249 

453 

333347 

256 

344357 

306 

353367 

356 

366433 

406 

422662 

456 

333358 

257 

344368 

307 

355434 

337 

366444 

407 

422673 

457 

333369 

258 

344435 

308 

355445 

358 

366453 

408 

422684 

438 

333436 

259 

344446 

309 

335456 

359 

366344 

409 

422695 

459 

333447 

260 

344457 

310 

355545 

360 

367322 

410 

422773 

460 

333458 

261 

344346 

311 

356323 

361 

367333 

411 

422784 

461 

333547 

262 

345324 

312 

356334 

362 

367344 

412 

423327 

462 

334325 

263 

345335 

313 

356345 

363 

367335 

413 

423338 

463 

334336 

264 

345346 

314 

356356 

364 

367422 

414 

423762 

464 

334347 

265 

345357 

315 

356423 

365 

367433 

415 

423773 

465 

334358 

266 

34S424 

316 

356434 

366 

367444 

416 

423784 

466 

334425 

267 

345435 

317 

356443 

367 

367453 

417 

423873 

467 

334436 

268 

345446 

318 

356456 

368 

367533 

418 

424427 

468 

334447 

269 

345457 

319 

356534 

369 

367544 

419 

424862 

469 

334458 

270 

345535 

320 

356345 

370 

368422 

420 

424873 

470 

334536 

271 

345546 

321 

357423 

371 

368433 

421 

423962 

471 

334547 

272 

346424 

322 

357434 

372 

368444 

422 

432226 

472 

335425 

273 

346435 

323 

357443 

373 

368S22 

423 

432237 

473 

335436 

274 

346446 

324 

337323 

374 

368S33 

424 

432248 

474 

335447 

275 

346524 

323 

357534 

375 

368544 

425 

432239 

475 

335525 

276 

346535 

326 

357545 

376 

368633 

426 

432337 

476 

335536 

277 

346546 

327 

357634 

377 

369322 

427 

432348 

477 

335547 

278 

346635 

328 

358323 

378 

369533 

428 

432772 

478 

335636 

279 

347524 

529 

358534 

379 

369622 

429 

432783 

479 

336525 

280 

347535 

330 

358623 

380 

369633 

430 

432794 

480 

336536 

281 

347624 

331 

358634 

381 

376332 

431 

433226 

481 

336625 

282 

347635 

332 

359623 

382 

376343 

432 

433237 

482 

336636 

283 

348624 

333 

339723 

383 

376354 

433 

433248 

483 

337625 

284 

348724 

334 

365222 

384 

376365 

434 

433326 

484 

337725 

285 

354223 

335 

365233 

385 

376443 

435 

433337 

485 

343224 

286 

354234 

336 

365244 

386 

376454 

436 

433348 

486 

343235 

287 

354245 

337 

365255 

387 

377332 

437 

433437 

487 

343246 

288 

354256 

338 

363266 

388 

377343 

438 

433772 

488 

343257 

289 

354267 

339 

365277 

389 

377334 

439 

433783 

489 

343268 

290 

354278 

340 

365333 

390 

377432 

440 

433872 

490 

343279 

291 

354334 

341 

365344 

391 

377443 

441 

433883 

491 

343335 

292 

354345 

342 

365355 

392 

377454 

442 

434326 

492 

343346 

293 

354356 

343 

365366 

393 

377543 

443 

434337 

493 

343357 

294 

354367 

344 

365444 

394 

378432 

444 

434426 

494 

343368 

295 

354445 

345 

365455 

395 

378443 

445 

434437 

495 

343446 

296 

354456 

346 

366222 

396 

378532 

446 

434872 

496 

343457 

297 

333223 

347 

366233 

397 

378543 

447 

434972 

497 

344224 

298 

335234 

348 

366244 

398 

379532 

448 

433426 

498 

344235 

299 

3S524S 

349 

366255 

399 

379632 

449 

435526 

499 
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Toble I : The t-sequence tobte. Cluster6 



Vul 


vol 

t-scq 

vol 

t-seq 

val 

t-seq 

1 

vol 

442225 

500 

454257 

550 

46634S 

600 

479322 

630 

543772 

700 

442236 

501 

454324 

551 

466423 

601 

479622 

631 

543872 

701 

442247 

502 

454335 

552 

466434 

602 

486332 

632 

544226 

702 

44 2268 

503 

454346 

553 

466443 

603 

486343 

633 

544326 

703 

442269 

504 

454357 

554 

466S34 

604 

486334 

634 

344426 

704 

442336 

505 

454435 

555 

467323 

603 

486443 

633 

332223 

705 

442347 

506 

454446 

556 

467334 

606 

487332 

636 

532236 

706 

442358 

507 

455224 

557 

467423 

607 

487343 

637 

352247 

707 

442447 

508 

455235 

558 

467434 

608 

487432 

638 

552258 

708 

443225 

509 

455246 

559 

467323 

609 

487443 

639 

552336 

7M 

443236 

510 

455324 

560 

467334 

610 

488432 

660 

552147 

710 

443247 

511 

455335 

561 

468423 

611 

488532 

661 

553225 

J*4tV 

71 1 
f 1 1 

443258 

512 

455346 

562 

468S23 

612 

497442 

662 

551716 

f l« 

443325 

513 

455424 

563 

468623 

613 

522552 

661 

551247 

7M 

443336 

514 

455435 

564 

475222 

614 

522563 

664 

551125 

7li 

443347 

515 

455446 

565 

475233 

615 

522574 

665 

551116 

715 

443358 

516 

455535 

566 

475244 

616 

5225S5 

666 

553347 

716 

443436 

517 

456324 

567 

475255 

617 

522663 

667 

553436 

717 

443447 

518 

456335 

568 

475266 

618 

522674 

668 

554225 

718 

444225 

519 

456424 

569 

475333 

619 

523652 

669 

554236 

719 

444236 

520 

456435 

570 

475344 

620 

523663 

670 

554325 

720 

444247 

521 

456524 

571 

475355 

621 

523674 

671 

554336 

721 

444325 

522 

456535 

572 

475444 

622 

523763 

672 

554425 

722 

444336 

523 

457424 

573 

476222 

623 

524752 

673 

554436 

723 

444347 

S24 

457524 

574 

476233 

624 

524763 

674 

555225 

724 

44442S 

525 

457624 

575 

476244 

625 

52S852 

675 

555325 

725 

444436 

526 

464223 

576 

476255 

626 

532227 

676 

555425 

726 

444447 

527 

464234 

577 

476322 

627 

532238 

677 

555525 

727 

444536 

528 

464245 

578 

476333 

62^ 

532662 

678 

561224 

7711 

445125 

529 

464256 

579 

476344 


532671 

67Q 

561215 

770 


530 

464267 

580 

476355 

w JV 


620 

561246 

710 

445425 

531 

464334 

581 

476433 

631 

532771 

681 

561257 

711 

445436 

532 

464345 

582 

476444 

632 

533227 

6A2 

561135 

717 

445325 

533 

464356 

583 

477222 

633 

533327 

623 

561346 

711 

445536 

534 

464445 

5M 

477233 

634 

531662 

6A4 

564224 

714 

446425 

535 

465223 

585 

477244 

635 

533671 

685 

564235 

715 

446525 

536 

465234 

586 

477322 

636 

533762 

6A6 

564246 

716 

f JO 

446625 

537 

465245 

587 

477113 

637 

531771 

fAl 

OO ' 

561 17i 

717 

453224 

538 

465256 

S88 

477344 

638 

51476^ 

fA% 

wOo 

5641^5 

Jv* J J J 

712 

' JO 

453235 

339 

465323 

589 

477422 

639 

534862 

689 

564346 

73Q 

453246 

540 

465334 

590 

477433 

640 

542226 

690 

364435 

740 

453257 

Ml 

465345 

591 

477444 

641 

542237 

691 

565224 

741 

453268 

542 

465356 

592 

477333 

642 

542248 

692 

565235 

742 

453335 

543 

465434 

593 

478322 

643 

542337 

693 

565324 

743 

453346 

544 

465445 

594 

478333 

644 

542772 

694 

565335 

744 

453357 

545 

466223 

595 

478422 

643 

542783 

693 

565424 

743 

453446 

546 

466234 

596 

478433 

646 

543226 

696 

565435 

746 

454224 

547 

466245 

597 

478522 

647 

543237 

697 

566214 

747 

454235 

548 

466323 

598 

478333 

648 

543326 

698 

566324 

748 

454246 

549 

466334 

599 

479422 

649 

543337 

699 

566424 

749 
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Table I 

: Th< 

B t-sequence table. Ciuster6 

1 

t-seq 

vo 

t-seq 

vol 

t-seq 

VO 

t^seq 

vol 

t-seq vol 

S66S24 

750 

621441 


674^14 


747447 

tTO 


574223 

751 

611453 

V**^ J J 

801 

O/^JJ J 

Ojl 

7474X1 

901 


574234 

752 

611464 

OvX 

O r J44^ 

fl<7 

6j4 

7414C7 
/4JJJ4 

yv2 



753 

VAX^ / J 

OUj 

O / J j44 

633 

/430j4 

AAV 

903 


S747SA 

7S4 

A77^<'t 
04XJJJ 

8U4 

IC7<4^4 
0/^44 

fl<X 
6M 

734062 

904 


J /*• 

7S^ 

A77<^ 

oUj 

#UL1>71 
054443 

633 

762426 

905 



7<A 
/ jO 

A7107 
OX^j4Z 

8U0 

064434 

636 

7T2125 

906 



7<7 

Ox^jjj 

fln7 

8v7 

664243 

837 

772236 

907 



7« 

/JO 

0xJjO4 

flfVO 

auo 

664334 

858 

773225 

AAA 

908 


C^C^J c 

7<0 

/ JT 

04 JO J 3 

809 

665223 

859 

773325 

909 




0x404/ 

810 

663234 

D^A 

860 

783224 

910 


J fjjj^ 

lit t 

044033 

O t 1 

811 

685323 

861 

783235 

911 


J fJj^J 


X7<7j7 

043742 

812 

665334 

862 

10 A 44 J 

784224 

912 



7Jtl 

Jd7<C1 

032332 

ail 
813 

686223 

863 

784324 

913 



/04 

034363 

814 

686323 

0^ A 

864 

794223 

914 



/o5 

632374 

815 

AMI 

686423 

865 

7*4234 

915 


<7^101 

7itX 
700 

632663 

816 

695222 

866 

795223 

916 


C7Alt^ 
J /Oj j4 

7jt7 
/07 

633332 

817 

695233 

0^<1 

867 

*iM^401 

795323 

917 


^7A4'>1 

7^ 
/Oo 

633363 

818 

695244 

868 

832332 

918 


J / 

7/M 

633632 

819 

6933 3 3 

869 

832343 

A • A 

919 


S77771 

J f 1 iAj 

770 

633003 

820 

d9d422 

Of A 

870 

832354 

A4A 

920 


J ' r J 

771 

til 

A14A<7 
0J40JX 

841 

oyo433 

671 

014^^1 

632443 

A4 1 

921 



777 


624 

OtOjZx 

674 

633432 

A 44 

922 



771 

04X44 / 

ft71 
B4J 

K<VC17l 

873 

833443 

A44 

923 


5fl<777 

77^ 

A4^Ai(7 
0^4004 

fl7^ 
844 

Oy/444 

Q^A 

674 

04J<14 

634332 

A^A 

924 


JO J J 

77^ 

0^40/ J 

84^ 

fyy73Z4 

673 

842442 

A4C 

923 


^fi57^1 

Jo JX^4 

77A 
/ /O 

^tM7 

8X0 

^Uk7X^^ 

697422 

676 

Oa4^ ffl 

842433 

926 


<oc7CC 

777 

Iff 

04 J /04 

8X/ 

722332 

877 

0 J 1 J 4 4 

843442 

927 


5«33j3 


632246 

828 

722343 

878 

843542 

928 


585344 

779 

632237 

829 

722354 

879 




55o222 

780 

632772 

830 

722365 

880 




586233 

781 

653226 

831 

722443 

881 




586244 

782 

633326 

832 

722454 

882 




586322 

783 

662225 

833 

723432 

883 




586333 

784 

662236 

834 

723443 

884 




5J50344 

785 

662247 

835 

723454 

885 


i 

5o0433 

"Tax 
7»0 

662336 

836 

723543 

886 


! 


787 

^^^^^ < 
6632x3 

837 

724332 

887 


1 

JO iZM 


XiC171X 

0oJ23o 

836 

724543 

888 


i 

3o73Z2 

789 

0033x3 

839 

725632 

889 


i 

587333 

790 

663336 

840 

732442 

890 


i 

587422 

791 

664223 

841 

732453 

891 


1 

587433 

792 

664325 

842 

732464 

892 


i 

588322 

793 

66442S 

843 

732553 

893 


i 

588422 

794 

673224 

844 

733442 

894 


i 


588522 

795 

673235 

845 

733453 

895 




596332 

796 

673246 

846 

733542 

896 




596343 

797 

673335 

847 

733533 

897 




597332 

798 

674224 

848 

734542 

898 




597432 

799 

674235 

849 

734642 

899 
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FIG . I7A 


../src/pdfl74.c 

» include <stciio.h> 
I define MODULE 9 

FILE -fopenO , ♦fout (9] ; 

int t[8]; 

int x(81 = (0,0,0,0,0,0,0,0); 

int b(13I = 10, 0,0, 0,0, 0,0, 0,0, 0,0,0, OJ; 

int m = 7; 

int n = 9; /*17 - 8*/ 

int other =0; 

int total = 0; 

int grteq(i) 

int i; 

( 

mt k.,flag; 

f lag=0; 
for (k=0; Jc<=m;lc++) if(x()c] >= i) flag^l; 
return (flag) ; 

1 


38 
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FIG. 17B 


void s(i) 
int i; 

{ 

int k, aumrjr tmp; 
suin«0; 

for {Jc=0;lc<i;k'»-+) sum x[k]; 
if <i == m) { 

x(m] = n - sum; 

for(k=0;k<m;k^"^) t(kl = x[k] -kx [k+1] ; 

tinp « x(0] - x[2] + x[4) - x(6); 

tmp « tmp%MODULE; 

if (tmp < 0) tmp •»-« MODULE; 

total++; 

if(grteq(6)) other+4'; 
else( bCtmp]-*"*-; 

for(k«0;)t<m;k-»-+) 

fprintf <fout (trap) , ",t(k]+2); 
fprintf (fout Ctmp) , "Xn") ; 

} 

}else{ 

for (j=0; j<=(n-sum) ; {x(il=j; 3(i-H) ; } 

} 

} 
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FI6.17C 


iTiain ( ) 

( 

int k; 


fout [OJ-£open("outO", "w") ; 
fout [IJ-fopenCoutl", "w") ; 
fout t2)«fop«n("out2","w") ; 
fout (3)»fop«n("out3", "w") ; 
fout (4)-£op«n(''out4'', "w") ; 
fout (Sl-fopenCoutS", "w") ; 
fout [6] "f open ("out 6", "w") / 
fout (7]-fop€n("out7'', "w") ; 
fout (8]=fopen("out8'*, "w") ; 
s ( 0 ) ; 

for ()c=0;lc<MCDULE fclcse {feu- [<] ) ; 
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FIG. 20 
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